2

我有一个来自我的 Mac App Store 应用程序的堆栈跟踪,我想阅读它以帮助诊断用户遇到的问题。我有 dSYM 文件和原始存档构建,但我没有完整的崩溃报告。我只想知道堆栈跟踪中方法的名称(您可以在下面看到其中两个用于MyAppName)。我无法获得lldbatos向我提供这些信息。这是堆栈跟踪的样子:

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文档,看起来我应该像这样调用它:

xcrun atos -arch x86_64 -o MyAppName.app/Contents/MacOS/MyAppName -l <LOADED ADDRESS> 0x0000000108e91c6b

但是,我将使用什么作为加载的地址?我所拥有的只是我在上面粘贴的内容。无论我使用0x0000000000000001,0x00007fff87df35fd还是完全省略-l,我都会将0x0000000108e91c6b(我指定的地址)打印回标准输出。

4

1 回答 1

1

在大多数转储堆栈跟踪的工具(特别是 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

然后进行上面列出的相同计算。

于 2014-10-22T17:21:08.940 回答