我有一个来自我的Mac App Store应用程序的堆栈跟踪,我想阅读以帮助诊断用户遇到的问题。我有dSYM文件和原始存档版本,但我没有完整的崩溃报告。我想知道的是堆栈跟踪中方法的名称(您可以在下面看到 MyAppName 中的两个)。我无法让lldb
或atos
向我提供此信息。这就是堆栈跟踪的样子:
0 CoreFoundation 0x00007fff92fdd25c __exceptionPreprocess + 172
1 libobjc.A.dylib 0x00007fff918dbe75 objc_exception_throw + 43
2 CoreFoundation 0x00007fff92ebb4f5 -[__NSArrayM objectAtIndex:] + 245
3 MyAppName 0x0000000108e91c6b MyAppName + 126059
4 MyAppName 0x0000000108e7556f MyAppName + 9583
5 AppKit 0x00007fff8d883099 -[NSToolbarButton sendAction:to:] + 75
6 AppKit 0x00007fff8d8830e8 -[NSToolbarButton sendAction] + 65
7 AppKit 0x00007fff8d436f0c -[NSToolbarItemViewer mouseDown:] + 4897
8 AppKit 0x00007fff8d352a58 -[NSWindow sendEvent:] + 11296
9 AppKit 0x00007fff8d2f15d4 -[NSApplication sendEvent:] + 2021
10 AppKit 0x00007fff8d1419f9 -[NSApplication run] + 646
11 AppKit 0x00007fff8d12c783 NSApplicationMain + 940
12 libdyld.dylib 0x00007fff87df35fd start + 1
13 ??? 0x0000000000000001 0x0 + 1
要获得符号(例如,上面的第3级),我可以使用什么命令?当我打电话给lldb
时,我甚至不清楚我是否应该使用十六进制地址或偏移量,如果那是126059在第3级的那个。
更新
根据atos
documentation,看起来我应该像这样调用它:
xcrun atos -arch x86_64 -o MyAppName.app/Contents/MacOS/MyAppName -l <LOADED ADDRESS> 0x0000000108e91c6b
但是我将使用什么作为加载地址?我所拥有的就是我粘贴在上面的东西。无论我使用0x0000000000000001
,0x00007fff87df35fd
还是完全遗漏-l
,我都会将0x0000000108e91c6b
(我指定的地址)打印回标准版。
答案 0 :(得分:1)
在大多数转储堆栈跟踪的工具(特别是CrashReporter)中,报告底部有一个部分,其中包含当前在程序中加载的所有图像,其UUID及其加载地址。您应该始终确保获取该信息以及堆栈跟踪,因为这样可以告诉您二进制文件的加载地址,并且还将确保您拥有正确版本的调试信息,因为您可以匹配针对dSYM或二进制文件中的UUID的UUID。
您可以使用&#34;符号名称+偏移量&#34;但是,部分跟踪可以确定加载地址。通常,最后一列是回溯中的地址与该二进制文件中最接近的未剥离符号的偏移量。因此,您只需在存储的二进制文件中找到该符号的地址,将偏移量添加到该地址,然后从上面第三列中列出的地址中减去该符号。在lldb中,您可以使用以下命令查找符号的地址:
(lldb) image lookup -n <SymbolName>
该计算将为您提供&#34;幻灯片&#34;二进制文件的默认加载地址。然后在二进制文件上运行lldb并执行:
(lldb) image load -f MyAppName -s <Calculated Slide>
现在,您可以使用以下方法在堆栈跟踪中查找MyAppName的地址:
(lldb) image lookup -va <ADDRESS>
但是,主要的可执行文件通常是完全剥离的 - 因为它们通常不提供符号供系统的任何其他组件使用,因此不会留下任何符号。在这种情况下,我猜测上面列表中的MyAppName只是二进制文件的__TEXT .__文本部分,尽管我并不是100%肯定。无论如何,如果这是正确的,您可以通过在lldb中加载二进制文件并执行以下操作来找到该部分的默认加载地址:
(lldb) image dump sections MyAppName
然后执行上面列出的相同计算。