NSNotification NSMetadataQueryDidUpdate获取不间断的通知消息

时间:2017-12-04 18:52:35

标签: swift ios11 icloud-drive

我正在我的应用程序中实现保存到iCloud Drive。现在我正在模拟器上测试应用程序。我可以将文件保存到iCloud Drive,它会按预期显示在驱动器上。在我的代码中,我实现了NotificationCenter.default.addObserver。在应用程序处于活动状态时调用startQuery()。这是代码示例:

@objc func startQuery()
{
    stopQuery()
    query = documentQuery()
    print( "adding notifications" )
    NotificationCenter.default.addObserver(self, selector: #selector(finishGatheringNotification(notifciations:)), name: NSNotification.Name.NSMetadataQueryDidFinishGathering, object:nil )
    NotificationCenter.default.addObserver(self, selector: #selector(didUpdateNotification(notifciations:)), name: NSNotification.Name.NSMetadataQueryDidUpdate, object:nil )
    query?.start()
}

@objc func stopQuery()
{
    guard let query = self.query else{
        return
    }
    NotificationCenter.default.removeObserver(self, name: NSNotification.Name.NSMetadataQueryDidFinishGathering, object:nil )
    NotificationCenter.default.removeObserver(self, name: NSNotification.Name.NSMetadataQueryDidUpdate, object:nil )
    query.stop()
    self.query = nil

}

     @objc func finishGatheringNotification( notifciations:NSNotification ){
        print( "called finished gathering notification" )
        processICloudFiles(notifciations: notifciations )
    }

    @objc func didUpdateNotification( notifciations:NSNotification ){
        // This seems to be getting called non-stop
        print( "called updated notification" )
        processICloudFiles(notifciations: notifciations )
    }

    @objc func processICloudFiles( notifciations:NSNotification )
    {
        guard let query = query else{
            return
        }
        query.disableUpdates()
        var metaDataItems:[NSMetadataItem] = []

        if let queryResults = query.results as? [NSMetadataItem]{
            print( "query results:\(queryResults.count)")
            for result in queryResults{
                if let fileURL = result.value(forAttribute: NSMetadataItemURLKey ) as? NSURL{
                     print( "file found in iCloud:\(String(describing: fileURL.lastPathComponent))")
                    metaDataItems.append( result )
                }
            }
            if metaDataItems.count > 0{
                updateICloudFiles(metaDataItems: metaDataItems)
            }
        }
        query.enableUpdates()
    }

然而,NSMetadataQueryDidUpdate的选择器被称为不停止。我认为只有当iCloud磁盘的内容发生变化时才会调用它。
有什么建议 由于

2 个答案:

答案 0 :(得分:0)

尝试取消初始化:

deinit {
    NotificationCenter.default.removeObserver(self)
}

答案 1 :(得分:0)

刚收到Apple发来的消息,这是一个已知错误,我发布了一个错误报告。