0

我正在尝试从 Parse 获取所有数据,并将这些数据与手机中的核心数据同步。我目前遇到了一个未正确执行的获取请求的小问题。我认为原因是我将 managedObjectContext 用于不同的任务,但我真的不知道如何解决这个问题。

我在我的代码中清楚地指出了问题发生的位置。这很奇怪,因为我的代码没有崩溃,只是在日志中打印了一个错误。(我已将显示的结果放在代码下方的日志中)

这是我的代码:

// CORE DATA UPDATE

for var i = 0; i < self.messages.count; i++ {
let entity = NSEntityDescription.entityForName("Groups", inManagedObjectContext: self.managedObjectContext)
let newGroup = Groups(entity: entity!, insertIntoManagedObjectContext: self.managedObjectContext)

newGroup.groupId = self.messages[i].groupId
newGroup.updatedAt = NSDate()
newGroup.groupName = self.messages[i].groupName
self.messages[i].imageFile.getDataInBackgroundWithBlock({ (imageData, error) -> Void in
    if error == nil{
        newGroup.photo = imageData
    }else{
        print(error)
    }
})
newGroup.lastMessage = self.messages[i].message

let usersRelationship = newGroup.mutableSetValueForKey("Users")
let arrayMembers = self.dictionaryGroupIds[self.messages[i].groupId]! as [String]

print(arrayMembers)

for member in arrayMembers {

    print(member) 
    print("CODE IS STOPPING HERE ")
    // MY CODE STOPS HERE

    // When I want to print the members in the arraymembers, it never displays all the member, sometimes it is only one member than it is 3 members, but never all of them so

    let fetchRequest = NSFetchRequest(entityName: "Users")
    fetchRequest.predicate = NSPredicate(format: "username = %@", member)
    fetchRequest.returnsObjectsAsFaults = false

    do {
        let result = try self.managedObjectContext.executeFetchRequest(fetchRequest)
        usersRelationship.addObject(result)
    }catch{
        let fetchError = error as NSError
        print("\(fetchError), \(fetchError.userInfo)")
    }
}

do {
    // This get never printed to the log
    print("SUCCESS")
    try newGroup.managedObjectContext?.save()
} catch {
    let saveError = error as NSError
    print("\(saveError), \(saveError.userInfo)")
    print("CRASH")
       }
   }
}

这是显示在日志中的内容:

2016-03-28 08:51:09.511 WeGrupp[1268:35749] Warning: A long-running operation is being executed on the main thread. 
 Break on warnBlockingOperationOnMainThread() to debug.
2016-03-28 08:51:09.823 WeGrupp[1268:35749] Warning: A long-running operation is being executed on the main thread. 
 Break on warnBlockingOperationOnMainThread() to debug.
["test1@info.com", "test2@info.com", "test3@info.com", "test4@info.com", "test5@info.com", "test6@info.com"]
te1t2@info.com
CODE IS STOPPING HERE
2016-03-28 08:51:10.140 WeGrupp[1268:35749] -[__NSArrayI entity]: unrecognized selector sent to instance 0x7fb0eb4d5c60
2016-03-28 08:51:10.143 WeGrupp[1268:35749] Warning: A long-running operation is being executed on the main thread. 
 Break on warnBlockingOperationOnMainThread() to debug.

所以就是这样,我认为它与并发有关,但不幸的是我找不到我的问题的答案。我一直在其他论坛上,但没有人能提供正确的答案。

非常感谢

4

1 回答 1

0

首先,最好通过中断来摆脱 Parse 警告warnBlockingOperationOnMainThread()。我在您当前的代码中看不到任何前台 Parse 调用,因此它必须在其他地方。这个 SO question有一个答案,显示了如何定义断点。

其次,以下代码值得关注:

self.messages[i].imageFile.getDataInBackgroundWithBlock({ (imageData, error) -> Void in
    if error == nil{
        newGroup.photo = imageData
    }else{
        print(error)
    }
})

newGroup是一个 CoreData 实体,你将要保存它的 MOC,但你也在后台更新它。作为一个简单的第一步,看看它是否导致了问题,注释掉这段代码。理想情况下,您只想在所有图像加载结束时保存一次 MOC。

第三,您的代码正在崩溃 - “无法识别的选择器发送到实例”。您可以通过中断所有异常来查看发生这种情况的位置。在断点导航器下执行此操作:

添加断点

于 2016-03-29T01:17:04.390 回答