Я пытаюсь получить некоторые данные из частной базы данных ClouKit. Запрос и предикат работают нормально, потому что я вижу в print(data) // 1
, что массив заполнен всеми данными. Но как только он уходит perform(){}
, массив сбрасывается до верхних определенных значений и просто возвращает их.
func fetchUserRecord() -> [Double] {
var data: [Double] = [0, 1, 2] //demo data
let aWeekAgo = Date().addingTimeInterval(-604800)
let privateDB = CKContainer.default().privateCloudDatabase
let predicate = NSPredicate(format: "Date > %@", aWeekAgo as NSDate)
let query = CKQuery(recordType: "ProgressionValue", predicate: predicate)
privateDB.perform(query, inZoneWith: nil) { records, error in
guard let records = records else { return }
for record in records {
data.append(record["Value"] as! Double)
}
data.append(0.0)
print(data) // 1
}
print(data) // 2
return data
}
Вот результаты:
печать (данные) //1: [0.0, 1.0, 2.0, {тонн двойников}, 0.0]
печать (данные) // 2: [0,0, 1,0, 2,0]
Что мне не хватает?
Спасибо @Larme, я определенно пропустил это, я также впервые работаю с асинхронными вызовами. Я прочитаю что-нибудь об этом и обновлю этот пост, как только выясню это. Большое вам спасибо за вашу помощь!
Попробуйте новые инструменты синхронизации;
func fetchUserRecord() async throws -> [Double]
{
var data: [Double] = [0, 1, 2] // you don't really want the
let aWeekAgo = Date().addingTimeInterval(-604800)
let privateDB = CKContainer.default().privateCloudDatabase
let predicate = NSPredicate(format: "Date > %@", aWeekAgo as NSDate)
let query = CKQuery(recordType: "ProgressionValue", predicate: predicate)
let (values, cursor) = try await privateDB.records(matching: query, resultsLimit: 100)
for r in values
{
if let rec = try? r.1.get()
{
data.append(rec["value"] as Double)
}
}
return x
}
Назовите это так;
Task
{
do {
data = try await fetchUserRecord()
}
catch
{
print(error)
}
}
//1 следует печатать после //2, не так ли? Вам не хватает асинхронности
perform(query:inZoneWith:completion:)
. Вам нужно использовать замыкание.