我想从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
(我指定的地址)打印回标准输出。 最佳答案
在大多数转储堆栈跟踪的工具(尤其是CrashReporter)中,报告底部都有一个部分,其中包含程序中当前加载的所有图像,它们的UUID和它们的加载地址。您应该始终确保获得该信息以及堆栈跟踪信息,因为这可以告诉您二进制文件的加载地址,并且还可以确保您具有正确版本的调试信息,因为您可以将UUID与UUID进行匹配在dSYM或二进制中。
但是,您可能可以使用跟踪的“符号名称+偏移量”部分来找出加载地址。通常,最后一列是回溯中的地址与该二进制文件中最接近的未剥离符号的偏移量。因此,您只需在存储的二进制文件中找到该符号的地址,将偏移量添加到该地址,然后从上面第三列中列出的地址中减去该偏移量即可。在lldb中,可以使用以下命令找到符号的地址:
(lldb) image lookup -n <SymbolName>
该计算将为您提供二进制文件从其默认加载地址开始的“幻灯片”。然后在二进制文件上运行lldb并执行以下操作:
(lldb) image load -f MyAppName -s <Calculated Slide>
现在,您可以使用以下命令在堆栈跟踪中从MyAppName查找地址:
(lldb) image lookup -va <ADDRESS>
但是,主要的可执行文件通常被完全剥离-因为它们通常不提供供系统的任何其他组件使用的符号,因此不存在任何符号。在那种情况下,我想上面清单中的MyAppName只是二进制文件的__TEXT .__ text部分,尽管我不确定100%。无论如何,如果正确,您可以通过在lldb中加载二进制文件并执行以下操作来找到该部分的默认加载地址:
(lldb) image dump sections MyAppName
然后执行上面列出的相同计算。
关于xcode - 从Mac应用程序的调用堆栈中获取符号名称,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25943933/