Dan*_*iel 5 crash debugging static-libraries debug-symbols ios
我从一个应用程序接收崩溃报告,但是Xcode不能表示我的应用程序专用的符号:
Thread 0 name: Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0 libsystem_kernel.dylib 0x32c43a1c __pthread_kill + 8
1 libsystem_c.dylib 0x33a0a3b4 pthread_kill + 52
2 libsystem_c.dylib 0x33a02bf8 abort + 72
3 libsystem_c.dylib 0x33a306d4 __assert_rtn + 140
4 MyApplication 0x0000dd54 0x9000 + 19796
5 MyApplication 0x0000dbda 0x9000 + 19418
6 MyApplication 0x000103f6 0x9000 + 29686
7 MyApplication 0x0001035e 0x9000 + 29534
8 MyApplication 0x0000f3cc 0x9000 + 25548
9 MyApplication 0x00025d1e 0x9000 + 118046
10 CoreFoundation 0x35847efc -[NSObject(NSObject) performSelector:withObject:] + 16
11 Foundation 0x36eec7a2 __NSThreadPerformPerform + 262
12 CoreFoundation 0x358b1a72 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 6
13 CoreFoundation 0x358b3758 __CFRunLoopDoSources0 + 376
14 CoreFoundation 0x358b44e4 __CFRunLoopRun + 224
15 CoreFoundation 0x35844ebc CFRunLoopRunSpecific + 224
16 CoreFoundation 0x35844dc4 CFRunLoopRunInMode + 52
17 GraphicsServices 0x3446b418 GSEventRunModal + 108
18 GraphicsServices 0x3446b4c4 GSEventRun + 56
19 UIKit 0x344a2d62 -[UIApplication _run] + 398
20 UIKit 0x344a0800 UIApplicationMain + 664
21 MyApplication 0x0000b174 main (main.m:14)
22 MyApplication 0x0000b124 0x9000 + 8484
Run Code Online (Sandbox Code Playgroud)
除了main.m中的行。我知道我的dSYM文件仍在Xcode的存档中。我尝试使用命令行直接引用那些调试符号,但是每次都会得到相同的结果。我尝试使用atos直接查找符号,但找不到它。通过比较UUID,我验证了它是正确的dSYM。
它每次都会找到main.m,因此似乎它工作了一半,但找不到其他东西。
我在此应用中使用静态库-静态库中是否可能发生崩溃?调试信息是否在单独的调试符号集中?它说负责的库是我的应用程序...会说静态库的名称,如果它实际上是导致崩溃的原因?
谢谢!
静态库已链接到您的应用可执行文件,因此在链接后,您将无法识别该代码的原始来源。因此,它将始终将您的应用程序命名为源二进制文件。
由于您包括的静态库,这些框架可能没有被符号化。如果静态库中没有符号,而是去除了符号,则会发生这种情况。对于静态库发行版,经常会发生这种情况,其中默认设置与应用程序相同,以去除符号。(对于应用程序,这是正确的操作!)
在那种情况下,这些符号将不会被复制到dSYM中,因为它无法在静态库中找到它们。
| 归档时间: |
|
| 查看次数: |
1941 次 |
| 最近记录: |