- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 ReadDirectoryChangesW
来监视我用 CreateFile
打开的文件夹,添加文件后我调用一个函数 (OnFileChanged
) 读取大小并打开它进行阅读,我的应用程序适用于小文件,但当我尝试将大文件复制到我的文件夹 (7,24 M) 时出现问题,并且我得到 Permission denied
调用 fopen 读取它后出错。
watching过程是根据this
void Init(const QString FullPath)
{ ...
hDir = CreateFile(
dirPath, // pointer to the directory containing the tex files
FILE_LIST_DIRECTORY|GENERIC_READ, // access (read-write) mode
FILE_SHARE_READ|FILE_SHARE_DELETE|FILE_SHARE_WRITE, // share mode
NULL, // security descriptor
OPEN_EXISTING, // how to create
FILE_FLAG_BACKUP_SEMANTICS | FILE_FLAG_OVERLAPPED , // file attributes
NULL); // file with attributes to copy
SecureZeroMemory (&overl, sizeof(overl));
SecureZeroMemory(buffer, sizeof(buffer));
overl.hEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
// watch the directory
BOOL res= ReadDirectoryChangesW(
hDir, /* handle to directory */
&buffer[curBuffer], /* read results buffer */
sizeof(buffer[curBuffer]), /* length of buffer */
FALSE, /* monitoring option */
FILE_NOTIFY_CHANGE_FILE_NAME ,
//FILE_NOTIFY_CHANGE_LAST_WRITE, /* filter conditions */
NULL, /* bytes returned */
&overl, /* overlapped buffer */
NULL); /* completion routine */
}
void StartWatchThread()
{
// if the thread already exists then stop it
if (IsThreadRunning())
SynchronousAbort();
//CrashIf(!hDir);
if(!hDir)
{ qDebug()<<" handle "<<hDir<<" last error"<<GetLastError();
exit(-1);}
else
{// reset the hEvtStopWatching event so that it can be set if
// some thread requires the watching thread to stop
ResetEvent(hEvtStopWatching);
DWORD watchingthreadID;
qDebug()<<"befrore creating thread";
hWatchingThread = CreateThread(NULL, 0, WatchingThread, this, 0, &watchingthreadID);
qDebug()<<"watchingthreadID"<<watchingthreadID;
}
}
DWORD WINAPI WatchingThread(void *param)
{
//qDebug()<<"in WatchingThread";
FileWatcher *fw = (FileWatcher *)param;
HANDLE hp[2] = { fw->hEvtStopWatching, fw->overl.hEvent };
for (;;)
{
DWORD dwObj = WaitForMultipleObjects((sizeof(hp)/(sizeof(hp[0])))
, hp, FALSE, INFINITE);
if (dwObj == WAIT_OBJECT_0) // the user asked to quit the program
{
qDebug()<<"in WatchingThread the user asked to quit the program";
//exit(-1);
break;
}
if (dwObj != WAIT_OBJECT_0 + 1)
{
// BUG!
//assert(0);
qDebug()<<"dwObj "<<dwObj<<" last error "<<GetLastError();
break;
}
//qDebug()<<"WatchingThread fw->NotifyChange() ";
//if (fw->wakeup)
fw->NotifyChange();
}
return 0;
}
bool NotifyChange()
{
//qDebug()<<"in NotifyChange";
GetOverlappedResult(hDir, &overl, &dwNumberbytes, FALSE);
FILE_NOTIFY_INFORMATION *pFileNotify = (FILE_NOTIFY_INFORMATION *)buffer[curBuffer];
// Switch the 2 buffers
curBuffer = (curBuffer + 1) % (sizeof(buffer)/(sizeof(buffer[0])));
SecureZeroMemory(buffer[curBuffer], sizeof(buffer[curBuffer]));
// start a new asynchronous call to ReadDirectory in the alternate buffer
ReadDirectoryChangesW(
hDir, /* handle to directory */
&buffer[curBuffer], /* read results buffer */
sizeof(buffer[curBuffer]), /* length of buffer */
FALSE, /* monitoring option */
FILE_NOTIFY_CHANGE_FILE_NAME ,
//FILE_NOTIFY_CHANGE_LAST_WRITE, /* filter conditions */
NULL, /* bytes returned */
&overl, /* overlapped buffer */
NULL); /* completion routine */
// Note: the ReadDirectoryChangesW API fills the buffer with WCHAR strings.
for (;;) {
if (pFileNotify->Action == FILE_ACTION_ADDED)
{
qDebug()<<"in NotifyChange if ";
char szAction[42];
char szFilename[MAX_PATH] ;
memset(szFilename,'\0',sizeof( szFilename));
strcpy(szAction,"added");
wcstombs( szFilename, pFileNotify->FileName, MAX_PATH);
OnFileChanged(szFilename,szAction);
qDebug()<<"in NotifyChange after OnFileChanged ";
}
// step to the next entry if there is one
if (!pFileNotify->NextEntryOffset)
return false;
pFileNotify = (FILE_NOTIFY_INFORMATION *)((PBYTE)pFileNotify + pFileNotify->NextEntryOffset);
}
pFileNotify=NULL;
return true;
}
我无法弄清楚如何处理该文件并且不让我阅读它?我试图在调用 OnFileChanged
后调用 Sleep() 并在它完成时唤醒但徒劳无功。请有任何想法。
最佳答案
I call a function (OnFileChanged) that read the size and open it for reading
这几乎肯定迟早会失败。文件更改通知是在进程写入文件时生成的。如果进程尚未完成写入或以其他方式保持文件打开,这将阻止您打开文件。并且不允许读取共享,这对于写入文件的程序来说很常见。这肯定与文件大小有关,文件越大,写入时间越长,因此您尝试打开它而其他进程尚未关闭它的可能性就越大。
您需要处理这种可能发生的事故。您只能将路径保留在队列中,以便稍后尝试。
关于c++ - CreateFile,ReadDirectoryChanges 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13063710/
我正在尝试使用 JNA 在 Windows 7 上调用 Win32 的 CreateFile 函数,目的是执行 this answer 的 Java 实现以检查文件是否正在被另一个进程使用。 我目前的
char tempFilename[256]; wchar_t filename[512]; fprintf(stdout, "Please enter file name/path: \n")
我正在尝试记录我使用 Windows-API 和 C 语言编写的服务所做的操作,因此我制作了一个日志文件系统。 问题是在每次调用 CreateFile 时,文件都会被覆盖,而不是仅仅打开它并在文件末尾
CreateFile()可以在两个不同的线程中同时打开一个文件吗 void new_function(void * what) { HANDLE h = CreateFile("c:\\tmp", G
知道为什么 createfile() 函数会返回 -1。 Handle = CreateFile(filename, &H80000000, 0, 0, 3, &H80, 0) 这运行了几次。我在想也
我想经常在文件中写入数据, 不知道是不是每次写的时候都调用 CreateFile() , 这种方式是否比我只调用一次的方式花费那么多,然后 多次使用 handle ? 最佳答案 如果要多次写入文件,最
我正在使用 CreateFile() 打开并读取文件。如果抛出异常,文件是否会被关闭,或者我是否需要捕获它并自己关闭文件。如果后者是真的,捕获并关闭文件的最佳方法是什么。谢谢! 最佳答案 文件不会关闭
HANDLE hFile = CreateFile(LPCTSTR("filename"), // name of the write
我正在尝试从 exe 文件所在的目录中读取文件。 data.txt 文件位于 VS Project 目录中,当我指定完整路径时,一切正常。 char curDirectory[MAX_PATH]; G
我正在使用 CreateFile打开设备。一切正常,直到设备名称太长。 在文档中说: In the ANSI version of this function, the name is limited
这个问题在这里已经有了答案: How to open COMXX files(serial port) (1 个回答) 关闭 7 年前。 我正尝试通过我的 USB 端口(名为 COM15)进行一些串
我正在窃取 plink 的源代码使其与统一兼容。 如果你不知道,unison 是一个文件同步工具,它运行一个“ssh”命令来连接到远程服务器,但 Windows 没有 ssh.exe;有 plink,
我正在使用 Delphi 2010,并正在寻找一种使用 CreateFile Windows API 函数追加数据而不是在指定文件中覆盖数据的方法? 我并不是在寻找一种可选的方法来做到这一点,例如 A
我正在尝试使用Golang 1.14中的windows.CreateFile()函数创建文件(有关引用,请参阅https://godoc.org/golang.org/x/sys/windows#Cr
所以我将这些东西从 C++ 移植到 C#。它的一部分看起来像这样: m_hParstat = CreateFile( _T("\\\\.\\LPTSTAT1"), GENERIC_READ
我在使用 Files.createFile() 的测试服务器上遇到了非常奇怪的行为。 代码如下: Files.createFile(myPath); ... code adding that file
程序在 Windows 计算机上创建一个文件来记录其进度。程序结束时,文件将关闭并保留在系统上。具有网络访问权限的用户希望远程打开文件以查看最近记录的条目。 该文件是使用fopen_s打开的,文档中没
我需要以原始模式打开读取磁盘,因此我为此目的使用了 CreateFile API 函数。 private static FileStream OpenDisk(string drive) {
我正在尝试利用 CreateFile 函数来访问目录信息。但是,我收到 win32 错误代码 5,这意味着访问被拒绝。请指教。 CreateFile(path, GENERIC_READ, FILE_
我拥有管理员权限,可以毫无问题地获得有效句柄并最终通过以下方式读取整个硬盘: IntPtr handle = CreateFile(@"\\.\PHYSICALDRIVE1", GENERIC_REA
我是一名优秀的程序员,十分优秀!