Может ли кто-нибудь объяснить Mutex и как он используется?
Я прочитал несколько документов о Mutex и все еще единственная идея, которую я получил, - это то, что она помогает предотвратить доступ нитей к ресурсу, который уже используется другим ресурсом.
Я получил фрагмент кода и выполнил его, который отлично работает:
#include <windows.h>
#include <process.h>
#include <iostream>
using namespace std;
BOOL FunctionToWriteToDatabase(HANDLE hMutex)
{
DWORD dwWaitResult;
// Request ownership of mutex.
dwWaitResult = WaitForSingleObject(
hMutex, // handle to mutex
5000L); // five-second time-out interval
switch (dwWaitResult)
{
// The thread got mutex ownership.
case WAIT_OBJECT_0:
__try
{
// Write to the database.
}
__finally {
// Release ownership of the mutex object.
if (! ReleaseMutex(hMutex)) {
// Deal with error.
}
break;
}
// Cannot get mutex ownership due to time-out.
case WAIT_TIMEOUT:
return FALSE;
// Got ownership of the abandoned mutex object.
case WAIT_ABANDONED:
return FALSE;
}
return TRUE;
}
void main()
{
HANDLE hMutex;
hMutex=CreateMutex(NULL,FALSE,"MutexExample");
if (hMutex == NULL)
{
printf("CreateMutex error: %d\n", GetLastError() );
}
else if ( GetLastError() == ERROR_ALREADY_EXISTS )
printf("CreateMutex opened existing mutex\n");
else
printf("CreateMutex created new mutex\n");
}
Но я не понимаю, где находится поток и где находится общий ресурс? Может ли кто-нибудь объяснить или предоставить лучшую статью или документ?
Ответы
Ответ 1
Мьютекс обеспечивает mut и ex клаусский доступ к ресурсу; в вашем случае, базу данных. В вашей программе не много потоков, но у вас может быть несколько экземпляров вашей программы, что защищает ваш мьютекс. Фактически, он по-прежнему защищает от доступа более чем из одного потока, просто чтобы эти потоки могли быть в отдельных процессах.
В вашем коде создается именованный мьютекс, который можно использовать для нескольких экземпляров приложения. Это форма межпроцессного общения. Документация MSDN на CreateMutex
содержит дополнительную полезную информацию о названных мьютексах:
Можно вызвать два или более процесса CreateMutex для создания одного и того же имени мьютекс. Первый процесс на самом деле создает мьютекс, а затем процессы с достаточным доступом права просто откройте дескриптор существующий мьютекс...
Несколько процессов могут иметь тот же объект мьютекса, позволяющий использовать объект для межпроцессного взаимодействия синхронизации.
Мьютекс необходим только здесь, если база данных, с которой вы работаете, не обеспечивает поддержку многопоточного доступа.
Ответ 2
Возможно, это будет лучший источник для вас.
http://en.wikipedia.org/wiki/Mutual_exclusion
Ответ 3
Эта ссылка в msdn предоставляет аналогичный пример с вашими потоками, выполненными в функции main(). Но опять же общий ресурс, который, как предполагается, является базой данных, не включен.
В любом случае, общий ресурс - это то, к чему должен быть обращен доступ из нескольких потоков: settingsfiles, drivers, database,...
Имейте в виду, что счетчик в примере написан, защищенный мьютексом, в то время как он был прочитан, пока он не защищен. Хотя в этом случае, вероятно, нет проблем, это немного неряшливо.
Ответ 4
Вы можете ссылаться на эту запись SO для сравнения различных механизмов синхронизации потоков
Разница между блокировками, мьютексом и критическими разделами
Если вам нужна конкретная информация Mutex, то wikipedia предоставит вам достаточно информации.