2

当我在模拟器中第二次启动应用程序时,应用程序崩溃并出现错误“线程 1:信号 SIGKILL”。第一次它会完美运行,但如果我完全关闭应用程序(双击主页按钮并关闭应用程序)并再次启动它 - 它会崩溃。

我发现其他人有同样的问题(应用程序第二次崩溃),但原因不同。

我尝试创建一个新项目来隔离错误,当我尝试以编程方式加载 ViewController 时会发生这种情况。

我做了两个简单的类:MainView 和 Loader(应该加载 MainView)。

在 Loader 类的 viewDidAppear 方法中,我有以下代码:

[super viewDidAppear:YES];

sleep(1); //Simulating to be doing stuff
MainView* mainView = [self.storyboard instantiateViewControllerWithIdentifier:@"MainView"];
[self presentViewController:mainView animated:YES completion:nil];

我得到以下回溯:

* thread #1: tid = 0x1f03, 0x9b5f5c22 libsystem_kernel.dylib`mach_msg_trap + 10, stop reason = signal SIGKILL
frame #0: 0x9b5f5c22 libsystem_kernel.dylib`mach_msg_trap + 10
frame #1: 0x9b5f51f6 libsystem_kernel.dylib`mach_msg + 70
frame #2: 0x0139b10a CoreFoundation`__CFRunLoopServiceMachPort + 186
frame #3: 0x012fe550 CoreFoundation`__CFRunLoopRun + 1312
frame #4: 0x012fdd84 CoreFoundation`CFRunLoopRunSpecific + 212
frame #5: 0x012fdc9b CoreFoundation`CFRunLoopRunInMode + 123
frame #6: 0x012b07d8 GraphicsServices`GSEventRunModal + 190
frame #7: 0x012b088a GraphicsServices`GSEventRun + 103
frame #8: 0x00011626 UIKit`UIApplicationMain + 1163
frame #9: 0x00001c4d progLoadingTest`main + 141 at main.m:16
frame #0: 0x9b5f5c22 libsystem_kernel.dylib`mach_msg_trap + 10
frame #1: 0x9b5f51f6 libsystem_kernel.dylib`mach_msg + 70
frame #2: 0x0139b10a CoreFoundation`__CFRunLoopServiceMachPort + 186
frame #3: 0x012fe550 CoreFoundation`__CFRunLoopRun + 1312
frame #4: 0x012fdd84 CoreFoundation`CFRunLoopRunSpecific + 212
frame #5: 0x012fdc9b CoreFoundation`CFRunLoopRunInMode + 123
frame #6: 0x012b07d8 GraphicsServices`GSEventRunModal + 190
frame #7: 0x012b088a GraphicsServices`GSEventRun + 103
frame #8: 0x00011626 UIKit`UIApplicationMain + 1163
frame #9: 0x00001c4d progLoadingTest`main + 141 at main.m:16
4

1 回答 1

0

我发现这对于您在模拟器中关闭然后在模拟器中重新启动的任何应用程序来说都是正常行为。我只是碰巧正在加载一个 ViewController。因此,它确实不是崩溃。

于 2012-11-15T19:44:26.193 回答