Вы должны прочитать и записать общую переменную внутри замка.Вы читаете его вне блокировки и, таким образом, делаете блокировку неактуальной.
Но даже этого недостаточно, поскольку ваша разделяемая переменная является переменной цикла, в которую вы пишете без защиты блокировки.Гораздо лучший пример будет выглядеть так:
#include <iostream>
#include <windows.h>
#include <process.h>
using namespace std;
void addQuery(void *v );
HANDLE ghMutex;
int counter = 0;
int main()
{
HANDLE hs[5];
ghMutex = CreateMutex( NULL, FALSE, NULL);
for(int i=0; i<5; ++i)
{
hs[i] = (HANDLE)_beginthread(addQuery, 0, NULL);
if (hs[i] == NULL)
{
printf("error\n"); return -1;
}
}
printf("WaitForMultipleObjects return: %d error: %d\n",
(DWORD)WaitForMultipleObjects(5, hs, TRUE, INFINITE), GetLastError());
return 0;
}
void addQuery(void *v)
{
WaitForSingleObject(ghMutex, INFINITE);
cout << counter << endl;
counter++;
ReleaseMutex(ghMutex);
_endthread();
}
Если вы можете, используйте критическую секцию, а не мьютекс, потому что они проще в использовании и более эффективны.Но у них та же семантика, что они защищают код только внутри блока блокировки.
Примечание: у Джерри есть указатель на некоторые другие проблемы, но я сконцентрировался на проблемах высокого уровня обработки и сериализации.