我有一个客户在使用iPad 2时发生崩溃,无法重现。

崩溃报告:

Last Exception Backtrace:
0   CoreFoundation                  0x37a5429e __exceptionPreprocess
1   libobjc.A.dylib                 0x32b3b97a objc_exception_throw
2   CoreData                        0x317438d8 +[NSEntityDescription entityForName:inManagedObjectContext:]
3   MyApp                           0x000fc916 -[DetailViewController fetchedResultsController] (DetailViewController.m:237)
4   MyApp                           0x000fc374 -[DetailViewController addToMySermons] (DetailViewController.m:170)
5   MyApp                           0x000fc080 -[DetailViewController actionSheet:didDismissWithButtonIndex:] (DetailViewController.m:140)
6   UIKit                           0x35db60cc -[UIActionSheet(Private) _popoutAnimationDidStop:finished:]
7   UIKit                           0x35a73aae -[UIViewAnimationState sendDelegateAnimationDidStop:finished:]
8   UIKit                           0x35ae88ca -[UIViewAnimationState animationDidStop:finished:]
9   QuartzCore                      0x30a91bd4 CA::Layer::run_animation_callbacks(void*)
10  libdispatch.dylib               0x358924b2 _dispatch_client_callout
11  libdispatch.dylib               0x358971b8 _dispatch_main_queue_callback_4CF$VARIANT$mp
12  CoreFoundation                  0x37a27f36 __CFRunLoopRun
13  CoreFoundation                  0x3799aeb8 CFRunLoopRunSpecific
14  CoreFoundation                  0x3799ad44 CFRunLoopRunInMode
15  GraphicsServices                0x3989a2e6 GSEventRunModal
16  UIKit                           0x35ab22f4 UIApplicationMain
17  MyApp                           0x000f595a main (main.m:16)
18  MyApp                           0x000f5910 start + 36

我可以看到它在+ [NSEntityDescription entityForName:inManagedObjectContext:]调用中发生,如下所示:
NSEntityDescription *entity = [NSEntityDescription entityForName:@"StoredPage" inManagedObjectContext:self.managedObjectContext];

self.managedObjectContext是从UISplitViewController左侧的UITableViewController传入的。

这对我和使用该应用程序的成千上万的其他用户来说都很好,只有这个人有问题。我们已经让他删除了该应用程序,然后重新安装并重新启动他的iPad,但这并没有帮助。

我有什么方法可以捕获抛出的实际异常并将其显示在UIAlertView中,以便可以看到实际发生的情况,还是我必须获取他的UDID并给他一个调试版本?

最佳答案

对我来说,问题在于ManagedObjectContext没有持久存储协调器。

为了发现抛出异常的细节,我做了以下工作
NSEntityDescription *entity = nil; @try { // do something entity = [NSEntityDescription entityForName:@"MyEntity" inManagedObjectContext:managedObjectContext]; } @catch (NSException *exception) { // error happened! do something about the error state NSLog(@"exception creating entity for managedobject content MyEntity = %@", exception); return nil; } @finally { // do something to keep the program still running properly }
其中记录了以下内容:

```

为托管对象内容创建异常的实体MyEntity = + entityForName:nil不是用于搜索实体名称“MyEntity”的合法NSPersistentStoreCoordinator

```

我很欣赏这是一个老问题,但是我怀疑这并不是一个罕见的问题。

关于ios - coredata间歇性崩溃[NSEntityDescription entityForName:inManagedObjectContext:],我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14367838/

10-13 03:21