iPhone OS上KERN_INVALID_ADDRESS
和KERN_PROTECTION_FAILURE
之间有什么区别?
我有一个来自ad-hoc beta测试者的两个崩溃报告,它们相隔5分钟,它们之间的主要区别(除了“二进制图像:”部分)是这一部分:
报告A:
Exception Type: EXC_BAD_ACCESS (SIGBUS)
Exception Codes: KERN_PROTECTION_FAILURE at 0x00000008
报告B:
Exception Type: EXC_BAD_ACCESS (SIGSEGV)
Exception Codes: KERN_INVALID_ADDRESS at 0x67696c69
对于它的价值,两者都有这样的痕迹:
Thread 0 Crashed:
0 libobjc.A.dylib 0x30011940 objc_msgSend + 20
1 UIKit 0x30940174 -[UIWindow _shouldAutorotateToInterfaceOrientation:] + 60
2 UIKit 0x30a223d8 -[UIWindow _updateToInterfaceOrientation:duration:force:] + 36
3 UIKit 0x30958638 -[UIWindow _updateInterfaceOrientationFromDeviceOrientation] + 112
4 UIKit 0x30942514 -[UIWindow _handleDeviceOrientationChange:] + 72
5 Foundation 0x3054dc7a _nsnote_callback + 178
6 CoreFoundation 0x3024ea52 _CFXNotificationPostNotification + 298
7 Foundation 0x3054b854 -[NSNotificationCenter postNotificationName:object:userInfo:] + 64
8 UIKit 0x309414a4 -[UIDevice setOrientation:] + 124
9 UIKit 0x30938330 -[UIApplication handleEvent:withNewEvent:] + 5232
10 UIKit 0x30936ce8 -[UIApplication sendEvent:] + 60
11 UIKit 0x30936874 _UIApplicationHandleEvent + 4336
12 GraphicsServices 0x32046964 PurpleEventCallback + 1028
13 CoreFoundation 0x30254a70 CFRunLoopRunSpecific + 2296
14 CoreFoundation 0x30254164 CFRunLoopRunInMode + 44
15 GraphicsServices 0x3204529c GSEventRunModal + 188
16 UIKit 0x308f0374 -[UIApplication _run] + 552
17 UIKit 0x308eea8c UIApplicationMain + 960
18 MyApp 0x00015e24 0x1000 + 85540
19 MyApp 0x0000f138 0x1000 + 57656
另外,我没有在代码中的任何地方实现“shouldAutorotateToInterfaceOrientation:”方法。
答案 0 :(得分:44)
EXC_BAD_ACCESS (SIGBUS) KERN_PROTECTION_FAILURE
表示虚拟地址显然是错误的:大多数CPU必须访问某个字节边界的内存。因为此处的数据访问是针对64位值(8)对齐的,所以它必须尝试执行获取128位值的指令(例如比较和交换指令CMPXCHG16B
)。在任何情况下,您可以从这里的示例中看到它是0x00000008
,这可能意味着您正在访问一个从开头偏移8个字节的结构元素,但您的结构指针是NULL
。
EXC_BAD_ACCESS (SIGSEGV) KERN_INVALID_ADDRESS
表示您正在参考的虚拟地址不在页面表中,或者您没有访问权限。这是一个您不允许访问的虚拟地址。对于您的示例地址地址0x67696c69
,这可能不是指针被视为指针;或者包含指针的数据结构是免费的,并用其他数据覆盖。
对于你的KERN_INVALID_ADDRESS
示例,指针数据拼出ASCII'ilig'(因为它是小端)。因此,存储指针的内存可能会被某种字符串覆盖。
在这两种情况下,都可能会覆盖UIWindow
中的数据结构。