你可以使用atos命令获取应用程序崩溃的行号。
以下是一个快速指南:
一旦您获得了所有所需的信息,请在终端中运行以下命令:
atos -o YourApp.app/Contents/MacOS/YourApp -arch x86_64 -l [load-address] [address]
例如,以下是从堆栈跟踪中提取的内容:
Process: MyApp [228]
Path: /Applications/MyApp.app/Contents/MacOS/MyApp
Identifier: uk.co.company.app
Version: 1.0 (1)
App Item ID: 774943227
App External ID: 218062633
Code Type: X86-64 (Native)
Parent Process: launchd [154]
Responsible: MyApp [228]
User ID: 501
Date/Time: 2013-12-17 10:20:45.816 +0100
OS Version: Mac OS X 10.9 (13A603)
Report Version: 11
Anonymous UUID: 7AA662B1-7696-A2C5-AF56-9D4BA2CE9515
Crashed Thread: 2
Exception Type: EXC_CRASH (SIGABRT)
Exception Codes: 0x0000000000000000, 0x0000000000000000
<snip>
Thread 2 Crashed:
0 libsystem_kernel.dylib 0x00007fff8b95a866 __pthread_kill + 10
1 libsystem_pthread.dylib 0x00007fff8bf4f35c pthread_kill + 92
2 libsystem_c.dylib 0x00007fff87571bba abort + 125
3 libsystem_malloc.dylib 0x00007fff897ae093 free + 411
4 uk.co.company.app 0x0000000103580606 0x10356e000 + 75270
5 uk.co.company.app 0x00000001035803da 0x10356e000 + 74714
6 com.apple.Foundation 0x00007fff8d00970b __NSThread__main__ + 1318
7 libsystem_pthread.dylib 0x00007fff8bf4e899 _pthread_body + 138
8 libsystem_pthread.dylib 0x00007fff8bf4e72a _pthread_start + 137
9 libsystem_pthread.dylib 0x00007fff8bf52fc9 thread_start + 13
我可以看到 "代码类型" 是 x86_64,第 2 线程崩溃了,在第 4 行代码运行时,我们有了需要的地址。根据这些信息,我执行以下操作:
$ atos -o MyApp.app/Contents/MacOS/MyApp -arch x86_64 -l 0x10356e000 0x0000000103580606
这将返回:
got symbolicator for MyApp.app/Contents/MacOS/MyApp, base address 100000000
obj_free (in MyApp) (somefile.c:135)
告诉我我的应用程序在somefile.c的第135行崩溃了。
@inkjet的评论应该得到自己的答案。 他建立了一个可以从您的dsym和.crash文件中进行完整符号化的应用程序。
我制作了一个Sumbolon的免费替代品:bch.us.to/apps/macsymbolicator - 它以Rich Able下面描述的方式使用atos。- inket Dec 24 '13 at 4:39
将它们全部组合起来:
从此处下载Mac Symbolicator
打开Xcode,选择“窗口”->“组织器”,转到存档选项卡并找到经历了崩溃的您的应用程序的版本。
右键单击应用程序存档并选择“在Finder中显示”
右键单击.xarchive,选择“显示内容”并找到AppName.dSYM目录
将您的.crash文件和AppName.dSYM拖到Sumbolon中
神奇的事情发生了
这个链接详细解释了如何使用行号来符号化崩溃日志。你只需要将.dsyms文件、.app文件和崩溃日志放在同一个文件夹中即可。
我找了很多资料,但没有比这更好的了。所以我希望这篇文章能帮到其他人。