在stopquery之前的metadataquery deallocation

时间:2015-04-26 01:53:42

标签: ios swift nsmetadataquery

我使用NSMetadataQuery获取iCloud ubiquity Documents目录中的文件列表,以便填充tableview。代码似乎正在工作,但我得到一个错误,指出在没有先调用stopQuery的情况下释放查询。我似乎无法找到关于这个主题的讨论。我在这里错过了一些简单的东西吗?

以下是查询和通知的功能:

var myMetadataQuery : NSMetadataQuery = NSMetadataQuery()
var cloudBackFiles : [AnyObject] = [AnyObject]()

func metadataForListOfFiles() {

    myMetadataQuery.predicate = NSPredicate(format: "%K like '*.sqlite'", NSMetadataItemFSNameKey)//change to "%K like '*.sqlite'"
    myMetadataQuery.searchScopes = [NSMetadataQueryUbiquitousDocumentsScope]

    NSNotificationCenter.defaultCenter().addObserver(self, selector: "metadataQueryDidFinishGathering:", name: NSMetadataQueryDidFinishGatheringNotification, object: myMetadataQuery)

    myMetadataQuery.startQuery()

}//metadataForListOfFiles

func metadataQueryDidFinishGathering(notification : NSNotification) -> [AnyObject] {

    let query : NSMetadataQuery = notification.object as! NSMetadataQuery
    query.disableUpdates()

    NSNotificationCenter.defaultCenter().removeObserver(self, name: NSMetadataQueryDidFinishGatheringNotification, object: query)

    query.stopQuery()

    let results = query.results

    cloudBackFiles = []

    if (query.resultCount >= 1) {
        println("query.resultCount = \(query.resultCount)")

        for var i = 0; i < query.resultCount; i++ {
            var forResultString = results[i].valueForAttribute(NSMetadataItemFSNameKey) as! String
            println("results[\(i)].value = \(forResultString)")
            var forResultStringNoExt = forResultString.stringByDeletingPathExtension
            cloudBackFiles.append(forResultStringNoExt)
        }//for

    } else {

        println("The query.resultCount was 0!")

    }//if count else
    println("cloudBackFiles list is: ")
    println(cloudBackFiles)

    //justForTest = results

    return results

}//metadataQueryDidFinishGathering(x)

这就是错误:

2015-04-24 22:49:38.367 [26397:2377464]正在取消分配     没有先调用-stopQuery。要避免竞争条件,您应该首先调用-stopQuery     在调用-startQuery的运行循环上

任何指导都将不胜感激。

1 个答案:

答案 0 :(得分:0)

我相信我是递归调用元数据查询。我重写了tableview控制器的viewDidLoad和viewWillAppear方法,现在我相信上面的代码工作正常。