符号化iOS崩溃堆栈跟踪没有崩溃日志

时间:2013-03-07 09:58:05

标签: ios crash stack-trace symbolicate bugsense

我正在使用BugSense来跟踪iOS应用中的崩溃。最近我注意到了在实际使用中象征堆栈跟踪的问题。

问题在于Apple引入了iOS 4.3的地址空间随机化,因此感兴趣的堆栈地址不能仅用于检索导致崩溃的正确方法。

目前我正在尝试通过计算

来获取正确的地址
symbol address = slide + stack address - load address

我已经有了幻灯片和堆栈地址但是根据我的理解,加载地址只能在我无法通过BugSense获取的崩溃报告中找到。 堆栈跟踪看起来像

0 CoreFoundation 0x342723e7 + 162
1 libobjc.A.dylib 0x3bf63963 objc_exception_throw + 30
2 CoreFoundation 0x3427229d + 0
3 Foundation 0x34b48fa3 + 90
4 UIKit 0x360b5bd9 + 7640
5 MyApp 0x000c6e99 0xb3000 + 81561
6 UIKit 0x3623c2ff 0x3607e000 + 1827583
7 UIKit 0x361b8737 0x3607e000 + 1287991
8 UIKit 0x361a9869 0x3607e000 + 1226857
9 UIKit 0x361a97ad 0x3607e000 + 1226669
10 CoreFoundation 0x34247941 0x341b0000 + 620865
11 CoreFoundation 0x34245c39 0x341b0000 + 613433
12 CoreFoundation 0x34245f1d 0x341b0000 + 614173
13 CoreFoundation 0x341b923d CFRunLoopRunSpecific + 356
14 CoreFoundation 0x341b90c9 CFRunLoopRunInMode + 104
15 GraphicsServices 0x37d9733b GSEventRunModal + 74
16 UIKit 0x360d52b9 UIApplicationMain + 1120
17 MyApp 0x000b61bf 0xb3000 + 12735
18 MyApp 0x000b4a08 0xb3000 + 6664

是否有其他方式来表示此地址或获取相应的加载地址?

1 个答案:

答案 0 :(得分:1)

load address0xb3000

幸运的是,您的应用二进制文件中删除了符号,否则无法看到。

此次崩溃也是因为抛出异常而发生的,因此崩溃报告应该会显示Last Exception Backtrace,显示实际异常发生的位置以及实际的异常原因。发布的堆栈跟踪的第5行中的调用很可能不会为您提供大量信息。您获得的崩溃信息看起来非常有限:(