Ios 核心数据迁移崩溃

Ios 核心数据迁移崩溃,ios,objective-c,iphone,core-data,large-data,Ios,Objective C,Iphone,Core Data,Large Data,我们的一些用户在核心数据迁移时崩溃 关于“核心数据迁移和崩溃”已经有几个问题,主要是关于内存使用和UI响应 苹果建议,对于高记忆峰值,这里是 当我试图重现这个问题时,比如使用轻量级迁移来迁移大型数据集,Xcode有时会因为内存使用而终止我的应用程序。因此,我认为我们的用户可能会遇到崩溃,因为同样的原因-内存不足 但是,@Marcus S.Zarra告诉我: @Jason Lee:轻量级迁移不会耗尽内存。也许你把它与糟糕的食物崩溃或其他事情混淆了?我建议打开一个新的SO问题并将链接发送给我

我们的一些用户在核心数据迁移时崩溃

关于“核心数据迁移和崩溃”已经有几个问题,主要是关于内存使用和UI响应

苹果建议,对于高记忆峰值,这里是

当我试图重现这个问题时,比如使用轻量级迁移来迁移大型数据集,Xcode有时会因为内存使用而终止我的应用程序。因此,我认为我们的用户可能会遇到崩溃,因为同样的原因-内存不足

但是,@Marcus S.Zarra告诉我:

@Jason Lee:轻量级迁移不会耗尽内存。也许你把它与糟糕的食物崩溃或其他事情混淆了?我建议打开一个新的SO问题并将链接发送给我马库斯·S·扎拉

因此,我提出了一个新问题:

  • 当应用程序在核心数据迁移时崩溃时,如何说明原因? 内存问题或没有UI响应
  • 如何解决这个问题
  • 谢谢

    更新1:添加崩溃日志

    @马库斯·S·萨拉,你说得对吃了不好的食物

    Date/Time:       2014-01-03 15:15:00.801 +0800
    OS Version:      iPhone OS 5.1.1 (9B206)
    Report Version:  104
    
    Exception Type:  00000020
    Exception Codes: 0x8badf00d
    Highlighted Thread:  0
    
    Application Specific Information:
    com.xxx.xxx failed to launch in time
    
    Elapsed total CPU time (seconds): 7.330 (user 7.330, system 0.000), 36% CPU 
    Elapsed application CPU time (seconds): 4.387, 21% CPU
    
    Thread 0 name:  Dispatch queue: com.apple.main-thread
    Thread 0:
    0   libsqlite3.dylib                0x317ae6ba ___lldb_unnamed_function176$$libsqlite3.dylib + 166
    1   libsqlite3.dylib                0x317a2846 ___lldb_unnamed_function128$$libsqlite3.dylib + 7934
    2   libsqlite3.dylib                0x317a06c2 sqlite3_step + 2098
    3   CoreData                        0x36924e2e _execute + 50
    4   CoreData                        0x36924d64 -[NSSQLiteConnection execute] + 2408
    5   CoreData                        0x369c7d54 -[NSSQLConnection prepareAndExecuteSQLStatement:] + 40
    6   CoreData                        0x36a19582 -[_NSSQLiteStoreMigrator performMigration:] + 590
    7   CoreData                        0x36a102b8 -[NSSQLiteInPlaceMigrationManager migrateStoreFromURL:type:options:withMappingModel:toDestinationURL:destinationType:destinationOptions:error:] + 1948
    8   CoreData                        0x369b5c02 -[NSMigrationManager migrateStoreFromURL:type:options:withMappingModel:toDestinationURL:destinationType:destinationOptions:error:] + 482
    9   CoreData                        0x36a01bf4 -[NSStoreMigrationPolicy(InternalMethods) migrateStoreAtURL:toURL:storeType:options:withManager:error:] + 176
    10  CoreData                        0x36a0119c -[NSStoreMigrationPolicy migrateStoreAtURL:withManager:metadata:options:error:] + 84
    11  CoreData                        0x36a02b58 -[NSStoreMigrationPolicy(InternalMethods) _gatherDataAndPerformMigration:] + 2188
    12  CoreData                        0x3691a20e -[NSPersistentStoreCoordinator addPersistentStoreWithType:configuration:URL:options:error:] + 3086
    

    因此,异步迁移数据?

    在我们完成此过程的同时,开始更新答案

    ,不是内存崩溃。那是看门狗撞车

    没有崩溃日志,但我怀疑它可能也是一个看门狗

    也是看门狗崩溃,而不是内存崩溃

    一旦我们看到你的坠机,我们就能知道发生了什么

    更新1 好的,
    0x8badf00d
    是我们的看门狗崩溃。这意味着您的应用程序启动时间过长

    如何解决这个问题

    不要在
    -applicationdFinishLaunching中竖起核心数据堆栈…
    是简单的答案

    一个快速修复方法是让应用程序的初始视图与启动图像(即启动屏幕)相同。然后,当您启动时,它会很快(非常快)完成
    -applicationdFinish…
    ,您可以花多长时间进行迁移

    我的建议(因为您不知道迁移需要多长时间)是:

  • 检查是否需要使用
    -[NSManagedObjectModel isConfiguration:compatibleWithStoreMetadata:][/code>
  • 更新视图显示,让用户知道正在进行迁移
  • 在后台块中执行迁移(将
    -addPersistentStore…
    放在块中并在后台队列中调用它,这是线程安全的,尽管最好在其周围放置锁)
  • 迁移完成后删除临时视图
  • 启动真正的用户界面

  • 这应该很容易改变,并且让你通过了监管机构。

    以下关于核心数据的新书中有代码,并解释了如何按照前面的答案进行后台手动迁移


    有一个崩溃日志供我们使用吗?我用LW做了一些非常大的迁移,从未弹出过内存,所以我对这个非常好奇。如果方便的话,我的另一个困惑的问题是。非常感谢。这个问题超出了我的专业范围,对不起。