xcode - 从Mac应用程序的调用堆栈中获取符号名称

标签 xcode macos cocoa debugging symbolicate

我有来自 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 时,甚至不清楚我是否应该使用十六进制地址或偏移量(如果这就是第 3 层的 126059)。

更新

根据atos documentation ,看来我应该像这样调用它:

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

但是我将使用什么作为加载地址?我所拥有的就是我上面粘贴的内容。无论我使用 0x00000000000000010x00007fff87df35fd,还是完全省略 -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/

相关文章:

swift - 关闭 NSWindow 后 WKWebView 不回收

iphone - 如何为 iPhone 中的所有属性使用两位数字格式化日期

xcode - 损坏的开发人员证书和配置文件

ios - 在 swift 项目中与 xmppframework 一起使用时出现 cocoalumberjack 问题

macos - Golang TLS握手超时,影响go get和go代码

macos - 为什么/bin/sh 在 Mac 和 Ubuntu 上表现不同

objective-c - cocoa 左栏菜单

ios - Xcode 8 MainStoryboard 显示蓝色矩形而不是对象

iphone - newViewController 始终带有两个 Nib (iPhone 和 iPad)

java - 每当我打开 Firefox 时,让我的计算机提示我预定的问题