搜尋

首頁  >  問答  >  主體

ios - CoreData多线程的同步问题

CoreData问题:需要对persistentCoordina加锁,但不知道加在哪些代码合适。不同的NSManagedObjectContext,但公用同一个NSPersistentCoordinator,是否允许两个线程同时进行读操作,而不对NSPersistentCoordinator进行lock?还是不管读和写,都需要对lock coordinator?
之前虽然是多线程操作coredata,没加lock,但是由于工作线程并没有很频繁的操作数据库,因此没出问题。但是现在我的工作线程需要2分钟一次对数据库进行查询、更新的逻辑,所以程序有时可以运行,有时executeFetch时候会卡死,报的错误是deadlock,死锁!很奇怪,我这时候根本就没对数据库加过锁啊!
是因为,coordinator对所有的操作,都会序列化(serialize operations),然后多线程操作coredata时候,我代码里面没有lock coordinator,所以就出现了deadlock的错误?
多谢大家的关注或回答啊!

PHPzPHPz2771 天前595

全部回覆(2)我來回復

  • 大家讲道理

    大家讲道理2017-04-17 11:08:30

    两分钟一次,一次多久,难道每次操作时间要到秒级吗?
    秒级的话自己给线程加个锁,时间更长的话要考虑数据缓存到内存等

    回覆
    0
  • 怪我咯

    怪我咯2017-04-17 11:08:30

    首先建议不要在多线程中操作同一份NSPersistentStoreCoordinator。
    多线程读写操作同一个NSPersistentStoreCoordinator确实有可能造成死锁。所以,建议每一个写操作都给NSPersistentStoreCoordinator加锁,避免思索出现

    回覆
    0
  • 取消回覆