iCloudquery = [[NSMetadataquery alloc] init];iCloudquery.searchScopes = @[NSMetadataqueryUbiquitousDataScope];Nsstring *filePattern = [Nsstring stringWithFormat:@"*.%@",@"txt"];iCloudquery.predicate = [nspredicate predicateWithFormat:@"%K liKE %@",NSMetadataItemFSnameKey,filePattern];[[NSNotificationCenter defaultCenter] addobserver:self selector:@selector(iCloudqueryDIDFinishGathering:) name:NSMetadataqueryDIDFinishGatheringNotification object:iCloudquery];[iCloudquery startquery];
当我收到通知时,resultCount为0表示查询
- (voID)iCloudqueryDIDFinishGathering:(NSNotification *)notification{ NSMetadataquery *query = [notification object]; [query disableupdates]; [query stopquery]; NSLog(@"Found %d results from Metadata query",query.resultCount);}
如果文件存在于iCloud中,NSMetadataquery是否应该返回resultCount,即使它尚未下载?有没有办法测试一个文件是否存在,而不是尝试超过和15-30秒后超时?
解决方法 查询可能需要一些时间才能从iCloud中检索元数据. dIDFinishGathering最初可能只保留设备已经知道的结果,而不是它没有机会从iCloud听到的变化.而不是停止和启动您的NSMetadataquery,最好设置一个并继续监听它,同时注册:
[[NSNotificationCenter defaultCenter] addobserver:self selector:@selector(iCloudqueryDIDUpdate:) name:NSMetadataqueryDIDUpdateNotification object:iCloudquery];
…并在它们进入时检索更新.因此,您还需要更改您的finishGathering方法,而不是停止查询,并在最后启用更新.
你必须重新考虑你的方法,以便第一组结果不一定知道所有内容.更常见的情况是,NSMetadataquery用于监视iCloud,期望其他设备生成的更改可以随时出现 – 而不仅仅是在应用程序启动时.
如果您需要确保拥有iCloud的最新元数据,我发现可靠的唯一方法(在iOS 5和iOS 6上)是将一个小文件注入iCloud(通常具有不同形式的name,并以UUID命名,因此保证是唯一的),然后在iCloudqueryDIDUpdate:方法中,在查询返回该文件之前不考虑查询结果是完整的,并且它的元数据报告它是也上传到iCloud.一旦你得到这个,你可以相当肯定你已经从iCloud收到了最新的元数据.
检查iCloudqueryDIDUpdate中的上传:使用:
int resultCount = [iCloudquery resultCount];for (int i = 0; i < resultCount; i++) { NSMetadataItem *item = [iCloudquery resultAtIndex:i]; BOol isuploaded = [[item valueForAttribute:NSMetadataUbiquitousItemIsuploadedKey] boolValue]; BOol isDownloaded = [[item valueForAttribute:NSMetadataUbiquitousItemIsDownloadedKey] boolValue]; NSURL *url = [item valueForAttribute:NSMetadataItemURLKey]; BOol documentExists = [[NSfileManager defaultManager] fileExistsAtPath:[url path]]; // You'll need to check isuploaded against the URL of the file you injected,rather than against any other files your query returns}
并且不要忘记在完成后删除注入的文件 – 否则每次启动应用程序时都会挂载.
编辑:
我实施这些检查的方式有一个内置的延迟,一旦我把它拿出来,我发现了一个上面不完全可靠的情况.
我已经删除了元数据项(在当前运行之前使用“设置/ iCloud /存储和备份/管理存储”删除)被报告为已上载和下载,并且在完整元数据返回到我的注入文件之前存在于磁盘上.但是,一旦注入的文件被报告为在磁盘上本地上载,下载和存在,其中一个已删除的文件仍然在上载和下载的元数据中列出 – 但不存在于磁盘上.
所以它看起来一直在发生的是iCloud守护进程听到有关旧数据的挂起删除,并且实际上在应用程序看到的元数据更新之前执行删除以反映这一点.疯了,是吗?因此,我必须更新上面的建议,仅在项目报告为已下载,上载时才考虑查询结果,并且使用[NSfileManager fileExistsAtPath:]方法将其存在于本地文件夹中.编辑上面的代码以反映这一点.
在此之后,你所做的就是在对查询结果采取行动之前坚持使用1秒钟的延迟,以确保所有元数据都有时间被接收 – 尽管这是我讨厌必须做的事情.在代码中加入虚假的时间延迟使其工作对我来说感觉有点太接近黑魔法了.并且表明您并不真正理解发生了什么 – 虽然没有更多关注iCloud背后的处理,我们还有什么可做的?
总结以上是内存溢出为你收集整理的ios – 如何确定iCloud文件夹中是否存在文件?全部内容,希望文章能够帮你解决ios – 如何确定iCloud文件夹中是否存在文件?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)