我的崩溃只发生在iOS7上。该应用程序是针对6.1 sdk编译的。我自己无法重现这一点,但我可以从崩溃报告中看到它正在为某些用户发生。问题是堆栈跟踪中没有用户代码,因此很难跟踪:
Exception Type: EXC_BAD_ACCESS Code: KERN_INVALID_ADDRESS at 0x13
0 libobjc.A.dylib objc_msgSend + 5
1 UIKit -[UIApplication sendAction:to:from:forEvent:] + 90
2 UIKit -[UIApplication sendAction:toTarget:fromSender:forEvent:] + 30
3 UIKit -[UIControl sendAction:to:forEvent:] + 44
4 UIKit -[UIControl _sendActionsForEvents:withEvent:] + 374
5 UIKit -[UIControl touchesEnded:withEvent:] + 590
6 UIKit -[UIWindow _sendTouchesForEvent:] + 528
7 UIKit -[UIWindow sendEvent:] + 832
8 UIKit -[UIApplication sendEvent:] + 196
9 UIKit _UIApplicationHandleEventQueue + 7096
10 ... CoreFoundation __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 14
16 UIKit UIApplicationMain + 1136
我尝试在应用中启用僵尸并执行各种操作,但没有标记任何内容。
我认为这可能已经转变为iOS 7.1下的[UIPickerView _updateSelectedRows],EXC_BAD_ACCESS。我会进一步调查。
Thread : Crashed: com.apple.main-thread
0 libobjc.A.dylib 0x39576626 objc_msgSend + 5
1 UIKit 0x3187b12f -[UIPickerView _updateSelectedRows] + 54
2 UIKit 0x3187b26f -[UIPickerView didMoveToWindow] + 78
3 UIKit 0x3160ad37 -[UIView(Internal) _didMoveFromWindow:toWindow:] + 1358
4 UIKit 0x3160aaa5 -[UIView(Internal) _didMoveFromWindow:toWindow:] + 700
5 UIKit 0x3160a40d __45-[UIView(Hierarchy) _postMovedFromSuperview:]_block_invoke + 112
6 UIKit 0x3160a263 -[UIView(Hierarchy) _postMovedFromSuperview:] + 250
7 UIKit 0x318a2a27 __UIViewWasRemovedFromSuperview + 218
8 UIKit 0x31609187 -[UIView(Hierarchy) removeFromSuperview] + 270
9 UIKit 0x316cf26f -[UIPeripheralHost(UIKitInternal) adjustHostViewForTransitionCompletion:] + 310
10 UIKit 0x31a6ca8b __53-[UIPeripheralHost(UIKitInternal) executeTransition:]_block_invoke1364 + 318
11 UIKit 0x3164378d -[UIViewAnimationBlockDelegate _didEndBlockAnimation:finished:context:] + 284
12 UIKit 0x316433d7 -[UIViewAnimationState sendDelegateAnimationDidStop:finished:] + 178
13 UIKit 0x316432ef -[UIViewAnimationState animationDidStop:finished:] + 66
14 QuartzCore 0x3128de0b CA::Layer::run_animation_callbacks(void*) + 234
15 libdispatch.dylib 0x39a55d3f _dispatch_client_callout + 22
16 libdispatch.dylib 0x39a586c3 _dispatch_main_queue_callback_4CF + 278
17 CoreFoundation 0x2eda6679 __CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE__ + 8
18 CoreFoundation 0x2eda4f45 __CFRunLoopRun + 1308
19 CoreFoundation 0x2ed0f7a9 CFRunLoopRunSpecific + 524
20 CoreFoundation 0x2ed0f58b CFRunLoopRunInMode + 106
21 GraphicsServices 0x33c6c6d3 GSEventRunModal + 138
22 UIKit 0x3166e891 UIApplicationMain + 1136
答案 0 :(得分:4)
我和我们的项目有几乎相同的崩溃日志,我们能够跟踪动画。
问题是我们在屏幕上和屏幕外动画UIPickerView。如果在动画期间弹出并取消分配拥有UIPickerView的ViewController。我们通过从动画完成块中的superview中删除UIPickerView来解决这个问题。
[UIView animateWithDuration:0.5f animations:^{
//Set the destination frame of the PickerView
} completion:^(BOOL finished) {
[self.pickerView removeFromSuperview];
}];
答案 1 :(得分:0)
我不了解其他崩溃报告工具,但Crashlytics包含CLS_LOG()宏: http://support.crashlytics.com/knowledgebase/articles/92519-how-do-i-use-logging
在开发期间,它的行为与NSLog()相同,但在现场,日志语句包含在崩溃报告中。所以我建议用CLS_LOG替换你的调试语句,或者开始使用大量捕获用户操作的语句来编写代码,然后部署新版本的应用程序。
(老问题,但我最近碰到了类似的东西,想记录下来。)
答案 2 :(得分:0)
所有我刚收到与UIPicker类似的崩溃。事实证明,在解除分配之前,我忘了将委托设置为nil。仅在启用断点运行时才会出现此问题。希望这有助于其他人。
答案 3 :(得分:-3)
尝试从
中删除arm64
Project > BuildSettings > Architectures> Valid Architectures
并重建你的应用。
您可能还需要将Build Active Architectures Only
设置为NO
才能生效。