gpt4 book ai didi

ios - 在 CKFetchRecordChangesOperation 上进行大量更改是否正常?

转载 作者:行者123 更新时间:2023-11-29 12:04:57 26 4
gpt4 key购买 nike

我在我的应用程序中使用 CloudKit,它似乎运行良好。但是,当我在新设备上初始化应用程序时,使用

CKFetchRecordChangesOperation *fetchRecordChangesOperation = [[CKFetchRecordChangesOperation alloc] initWithRecordZoneID:zoneID previousServerChangeToken:NIL];

我得到了很多更改,因为所有之前的删除和更改似乎都是同步的。

有没有更好的方法?例如,只需下载一整套当前数据并将 serverChangeToken 设置为当前值。

最佳答案

在查看 CKServerChangeToken 的文档时,看起来您只能在使用 CKFetchRecordChangesOperation 时才能获得它。请参阅:https://developer.apple.com/library/prerelease/ios/documentation/CloudKit/Reference/CKServerChangeToken_class/index.html

那么现在您如何才能获得该 token :

通常你会做这样的事情:正如你在 CKFetchRecordChangesOperation 中看到的,你可以用 previousServerChangeToken 初始化它。此 token 的作用类似于时间戳。操作完成后,您将在 fetchRecordChangesCompletionBlock 中取回此 token 。您必须将该 token 保存在例如用户默认值中。然后下次启动 CKFetchRecordChangesOperation 时,您可以使用该 token 开始读取自上次调用以来发生的更改。

实际上保存 token 可能有点棘手。我可以建议添加这样的属性:

private var previousChangeToken: CKServerChangeToken? {
get {

let encodedObjectData = NSUserDefaults.standardUserDefaults().objectForKey("\(container.containerIdentifier)_lastFetchNotificationId") as? NSData
var decodedData: CKServerChangeToken? = nil
if encodedObjectData != nil {
decodedData = NSKeyedUnarchiver.unarchiveObjectWithData(encodedObjectData!) as? CKServerChangeToken
}
return decodedData
}
set(newToken) {
if newToken != nil {
NSUserDefaults.standardUserDefaults().setObject(NSKeyedArchiver.archivedDataWithRootObject(newToken!), forKey:"\(container.containerIdentifier)_lastFetchNotificationId")
}
}
}

在您的情况下,您希望新应用程序以只能由其他正在运行的应用程序创建的更改 token 开始。因此,除了将更改 token 保存到 NSUserDefaults 之外,您还应该将其保存在 CloudKit 中的公共(public)数据库中的一个特定设置 recordType 记录中。新安装的应用程序在其 NSUserDefaults 中没有 token ,然后可以从您的 CloudKit 设置记录中读取 token 。

关于ios - 在 CKFetchRecordChangesOperation 上进行大量更改是否正常?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35409393/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com