And*_*sov 5 macos cocoa fsevents
这让我很伤心,我不确定我知道如何调试它。
我正在使用 Mac FSEvents API 来监视文件系统上的给定文件夹。但是,有时,某些文件夹会停止发送任何通知事件。到目前为止,这仅发生在 ~/Dropbox 中的文件夹中,并且只影响了我的应用程序的少数用户(并且也经常影响我)。
疯狂的部分是“治愈”文件系统的方法是:
mv ~/Dropbox/some/stuck/folder ~/Dropbox/some/stuck/folder.0
mkdir ~/Dropbox/some/stuck/folder
mv ~/Dropbox/some/stuck/folder.0/* ~/Dropbox/some/stuck/folder/
rmdir ~/Dropbox/some/stuck/folder.0
Run Code Online (Sandbox Code Playgroud)
运行这些命令后,文件夹会解开并开始发送事件!需要尝试几次才能找到哪个父文件夹是罪魁祸首,但它始终是 Dropbox 中的某个文件夹。(退出 Dropbox 或重新启动并不能治愈它。)
我在我的代码中没有做任何特别的事情。监控开始使用:
FSEventStreamContext context;
context.version = 0;
context.info = self;
context.retain = NULL;
context.release = NULL;
context.copyDescription = NULL;
_streamRef = FSEventStreamCreate(nil,
(FSEventStreamCallback)FSMonitorEventStreamCallback,
&context,
(CFArrayRef)paths,
kFSEventStreamEventIdSinceNow,
0.25,
kFSEventStreamCreateFlagUseCFTypes);
if (!_streamRef) {
NSLog(@"Failed to start monitoring of %@ (FSEventStreamCreate error)", _path);
}
FSEventStreamScheduleWithRunLoop(_streamRef, CFRunLoopGetCurrent(), kCFRunLoopDefaultMode);
if (!FSEventStreamStart(_streamRef)) {
NSLog(@"Failed to start monitoring of %@ (FSEventStreamStart error)", _path);
}
Run Code Online (Sandbox Code Playgroud)
回调看起来像这样(并不重要):
static void FSMonitorEventStreamCallback(ConstFSEventStreamRef streamRef, FSMonitor *monitor, size_t numEvents, NSArray *eventPaths, const FSEventStreamEventFlags eventFlags[], const FSEventStreamEventId eventIds[]) {
for (int i = 0; i < numEvents; i++) {
NSString *path = [eventPaths objectAtIndex:i];
FSEventStreamEventFlags flags = eventFlags[i];
[monitor sendChangeEventWithPath:path flags:flags];
}
}
Run Code Online (Sandbox Code Playgroud)
发生在 10.6 和 10.7 上。没有像 FileVault 这样的花哨的东西是活跃的。
在我看来,这确实是一个操作系统错误,但我在网上没有发现任何提及此问题的内容。
问题是:
1) 你有过这样的经历吗?有什么发现吗?
2) 在使用技术支持事件之前,进一步诊断此问题的步骤是什么?
这是 OS X 中已知的“FSEvents”错误。它可能会产生各种难以追踪的问题。有关该问题的更多信息,请参阅此页面。特别是,该页面有一个GitHub 存储库的链接,其中包含一个实用程序,可以查找计算机上易受此问题影响的所有目录(不必位于您的 DropBox 文件夹中)。
归档时间: |
|
查看次数: |
1450 次 |
最近记录: |