我们应该在 CKDatabase 和 CKRecordZone 中分别缓存一个 CKServerChangeToken 吗?

Should we cache a CKServerChangeToken in CKDatabase and CKRecordZone separately?

在我的应用程序中,我使用 CloudKit 和用户的私有 CKDatabase 来存储记录。当应用程序启动时,我会按照它在 WWDC 2016 上的建议获取更改。

首先,我调用 fetchDatabaseChanges(database: CKDatabase, databaseTokenKey: String, completion: @escaping () -> Void) 方法。 在 changesOperation.fetchDatabaseChangesCompletionBlock 的这个方法中,我将一个 CKServerChangeToken 保存到 userDefaults 中作为一个键:ckDatabaseToken.

我也在fetchDatabaseChanges方法的changesOperation.fetchDatabaseChangesCompletionBlock中调用了fetchZoneChanges(database: database, databaseTokenKey: databaseTokenKey, zoneIDs: changedZoneIDs, completion

fetchZoneChanges方法中有一个operation.recordZoneFetchCompletionBlock。在这个块中,我们还需要将令牌的值保存到 UserDefaults。我将它保存到用户默认值中的另一个 ckZoneToken 变量。所以在 fetchZoneChanges 中,我获取并保存 (from/to UserDefaults) ckZoneToken 值,在 fetchDatabaseChanges 中,我获取并保存 (from/to UserDefaults) ckDatabaseToken 值 .

这是正确的技术吗?或者在fetchDatabaseChangesfetchZoneChanges方法中只使用一个变量来存储CKServerChangeToken的值更好?

哪种方法最好?

Swift3,Xcode9

我已经尝试了两种方法,发现如果我们在用户默认设置中使用一个 changeToken,我们会得到一个 "Bad sync continuation data" 错误。

当我使用 2 个单独的值来存储数据库更改和区域更改时,我没有出现任何错误。

所以,我认为我们必须分别在 CKDatabase 和 CKRecordZone 中缓存一个 CKServerChangeToken。