现在有很多第三方的错误信息收集SDK,百度的crab 友盟 bugly等等,但有些不能直接展示crash的位置,比如百度的crab,在这种情况下怎么根据错误堆栈去定位代码呢?
1、选中xcode 点击菜单上的window - Organizer

2、找到想要查看的版本,右键 show in Finder,在文件夹中 右键.xcarchive文件显示包内容 --- dSYMs ---xxx.app.dSYM


3、我们可以用命令行检查一下dsym 所支持的UUID,此UUID可以确定设备的架构类型(arm64, armv7, armv7s 等)
通过命令行:dwarfdump --uuid xxx(.app.dsym)

4、xxx.app.dSYM 右键显示包内容 -- Contents --- Resources -- DWARF ---

5最后我们可以利用这个文件定位错误代码的具体的位置。
定位错误命令行:
xcrun atos -o xxx(App1031的路径) -arch armv7/armv7s/arm64(选其一) -l xxx(起始地址) xxx(运行地址)、

到这里就可以了 如 DeleteHistoryTrajectoryVC.m m:291
关于开始地址 和 结束地址

网友评论