默认情况下,LockFileEx 会阻塞直到可以获取锁(尽管您可以通过 LOCKFILE_FAIL_IMMEDIATELY 告诉它不要这样做)。
显然这不是跨平台的。
更新
这个可怕的代码示例说明了它的工作原理(您可能需要将 CreateFile 中的文件名从“lockBlock.cpp”更改)。运行程序的一个实例,它将获得锁。运行第二个实例,它将阻塞。在第一个实例中按释放锁,第二个实例将解锁并获取锁。
int _tmain(int argc, _TCHAR* argv[])
{
HANDLE hFile = ::CreateFileA("lockBlock.cpp", GENERIC_READ, FILE_SHARE_READ, 0, OPEN_EXISTING, 0, 0);
OVERLAPPED overlapped;
memset(&overlapped, 0, sizeof(overlapped));
const int lockSize = 10000;
printf("Taking lock\n");
if (!LockFileEx(hFile, LOCKFILE_EXCLUSIVE_LOCK, 0, lockSize, 0, &overlapped))
{
DWORD err = GetLastError();
printf("Error %i\n", err);
}
else
{
printf("Acquired lock\n");
getchar();
UnlockFileEx(hFile, 0, lockSize, 0, &overlapped);
printf("Released lock\n");
}
return 0;
}