我正在尝试分析iPhone崩溃报告。

还有一些我不明白的地方:

Thread 6 crashed with ARM Thread State:
r0: 0x00000000    r1: 0x00000000      r2: 0x00000001      r3: 0x00000000
r4: 0x077aa000    r5: 0x00000006      r6: 0x0010540c      r7: 0x077a9198
r8: 0x001a0420    r9: 0x00000065     r10: 0x3fcb8acc     r11: 0x310d1b68
ip: 0x00000148    sp: 0x077a918c      lr: 0x36ba33bb      pc: 0x32a29a1c
cpsr: 0x00000010

什么是r0,r1,rx?

当我看到:
r3: 0x00000000

我可以假设“对象” r3为零吗?

欢迎您提供任何帮助来了解有关carshlogs的其他信息:-)

最佳答案

这些是ARM处理器的寄存器,就像它们在处理该线程一样。

对于大多数rX寄存器,最好将它们视为对象的指针,而不是对象本身。但是,它们也可以保存直接值或地址。

“pc”寄存器包含处理器试图执行的代码的最后地址。这有助于说明EXC_BAD_ACCESS之间的差异,该差异是由于尝试取消引用nil指针和尝试从地址零执行代码而引起的。

您可以在这里找到Apple的使用说明文件:
http://developer.apple.com/library/ios/#documentation/Xcode/Conceptual/iPhoneOSABIReference/Articles/ARMv6FunctionCallingConventions.html

10-06 15:03