我使用CreateFile api,有时随机失败并出现错误: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)和mode = FILE_WRITE
答案 0 :(得分:7)
CreateFile没有任何问题 - 共享冲突意味着其他东西打开了同一个文件。这可能是您自己的程序,如果您以共享模式0打开文件,您将无法再次打开它。
当您收到错误消息时,您可以使用Process Explorer来确定文件打开的进程。
答案 1 :(得分:1)
机器上有防病毒吗?有时AV(或其他监视文件的软件)操作和时间可能会导致共享冲突。
如果您要打开现有文件以进行独占访问,则尤其如此(如果该文件已存在,则FILE_WRITE
和FILE_APPEND
情况就是如此。
答案 2 :(得分:1)
我的意思是没有不尊重,但我上周在类似的事情上开枪自杀:
您确定没有其他任何文件以阻止请求访问的方式打开文件吗?
在我的情况下,我在Linux命令窗口中使用了ctrl-Z来暂停创建套接字连接的程序,然后我去睡觉了。第二天早上经过一些简单的更改后,我在运行程序时不断“无法创建socket:service in use”消息。可悲的是,我花了几个小时调试我已经破坏的东西。一旦我杀了违规的暂停过程,它就运行良好。
答案 3 :(得分:0)
微软称here这可能会发生,并且由应用程序重新启动。可是但是你去了。