我使用CreateFile api,有時候它會隨機失敗,錯誤:ERROR_SHARING_VIOLATION。CreateFile失敗,錯誤ERROR_SHARING_VIOLATION
我已經用Google搜索了,這個錯誤幾乎沒有。奇怪的是,下次打開同一個文件也很開心。
這裏是我的代碼:
void FileHandle::open(const char* fileName, FILE_MODE mode)
{
if (m_bIsOpen)
close();
HANDLE fh = NULL;
DWORD dwDesiredAccess = GENERIC_READ;
DWORD dwShareMode = FILE_SHARE_READ;
DWORD dwCreationDisposition = OPEN_EXISTING;
switch (mode)
{
case FILE_READ:
break;
case FILE_WRITE:
dwDesiredAccess = GENERIC_WRITE;
dwShareMode = 0;
dwCreationDisposition = CREATE_ALWAYS;
break;
case FILE_APPEND:
dwDesiredAccess = GENERIC_WRITE;
dwShareMode = 0;
dwCreationDisposition = OPEN_ALWAYS;
break;
default:
throw gcException(ERR_INVALID, "The mode was invalid");
break;
}
fh = CreateFile(fileName, dwDesiredAccess, dwShareMode, NULL, dwCreationDisposition, 0, NULL);
if (!fh || fh == INVALID_HANDLE_VALUE)
throw gcException(ERR_INVALIDFILE, GetLastError(), gcString("Failed to open the file {0}", fileName));
m_hFileHandle = fh;
m_bIsOpen = true;
if (mode == FILE_APPEND)
{
DWORD high = 0;
DWORD low = GetFileSize(fh, &high);
uint64 pos = (((uint64)high)<<32) + (uint64)low;
seek(pos);
}
}
難道我做錯了什麼或有與API的問題嗎?
編輯:使用 進出口完整的文件名(即C:\ somefile.txt)和模式= FILE_WRITE
呼叫失敗時會運行哪種情況?你也應該只在文件句柄等於INVALID_HANDLE_VALUE時檢查,不檢查它是否爲NULL。還請在拋出之前移動GetLastError調用並將其存儲在DWORD中。 – 2010-12-14 02:06:39
無關緊要,如果我檢查它對NULL,錯誤代碼是32(認爲我混淆了,應該是ERROR_SHARING_VIOLATION)。 – Lodle 2010-12-14 02:13:11
使用進程監視器(http://technet.microsoft.com/en-us/sysinternals/bb896645)併爲要打開的文件的路徑設置篩選器。檢查是否沒有其他進程(例如反惡意軟件,桌面搜索,備份)正在打開它。 – 2010-12-14 02:48:22