【发布时间】:2023-03-14 14:50:02
【问题描述】:
我们的一些用户在迁移核心数据时崩溃。
关于“Core Data Migration & crash”已经有几个问题了,主要是内存使用和UI响应。
Migrating large Core Data database crash
Out-Of-Memory while doing Core Data migration
Core Data causing app to crash while migrating
Core Data lightweight migration crash
对于高内存峰值,苹果建议multiple passes solution,这里是another large datasets solution。
当我尝试重现问题时,例如使用轻量级迁移来迁移大型数据集,Xcode 有时会由于内存使用而终止我的应用程序。所以我认为我们的用户可能会因为同样的原因遇到崩溃 - 内存不足。
但是,@Marcus S. Zarra 告诉我:
@Jason Lee:轻量级迁移不会耗尽内存。也许您将其与糟糕的食物崩溃或其他事情混淆了?我建议打开一个新的 SO 问题并将链接发送给我。 ——马库斯·S·扎拉
所以我创建了这个新问题来问:
- Core Data Migration 应用崩溃时如何判断原因? 内存问题或没有 UI 响应。
- 如何解决问题?
谢谢。
更新 1:添加崩溃日志
@Marcus S. Zarra,你是对的。 吃了不好的食物...
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
那么,异步迁移数据?
【问题讨论】:
-
有崩溃日志供我们使用吗?我用 LW 做了一些非常大的迁移,从来没有弹出内存,所以我对这个很好奇。
标签: ios objective-c iphone core-data large-data