我正在尝试分析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