现在有很多第三方的错误信息收集SDK,百度的crab 友盟 bugly等等,但有些不能直接展示crash的位置,比如百度的crab,在这种情况下怎么根据错误堆栈去定位代码呢?
1、选中xcode 点击菜单上的window - Organizer
xcode 菜单点击Organizer
2、找到想要查看的版本,右键 show in Finder,在文件夹中 右键.xcarchive文件显示包内容 --- dSYMs ---xxx.app.dSYM
点击Show in Finder.png 这个.png
3、我们可以用命令行检查一下dsym 所支持的UUID,此UUID可以确定设备的架构类型(arm64, armv7, armv7s 等)
通过命令行:dwarfdump --uuid xxx(.app.dsym)
4、xxx.app.dSYM 右键显示包内容 -- Contents --- Resources -- DWARF ---
找到这个东西 名字是你自己的名字哈.png
5最后我们可以利用这个文件定位错误代码的具体的位置。
定位错误命令行:
xcrun atos -o xxx(App1031的路径) -arch armv7/armv7s/arm64(选其一) -l xxx(起始地址) xxx(运行地址)、
到这里就可以了 如 DeleteHistoryTrajectoryVC.m m:291
网友评论