利用.dSYM和.app文件准确定位Crash位置

当发布到iPhone上的应用程序Crash之后,iPhone会自动生成一个Crash Log(*.crash),这个文件包含了一些有用的调试信息,但对于堆栈,它只记录的函数地址,而无法显示函数名。函数名保存在一个叫dSYM的二进制文件中,即一个调试符号表文件。

首先,确保在release(Ad Hoc或者App Store)一个版本时,保存了对应的xxx.app和xxx.dSYM文件。

其次,验证xxx.crash、xxx.app和xxx.dSYM三者的uuid是否一致。

验证方法:

1)查看xxx.app的uuid。

[plain] view plaincopyprint?在CODE上查看代码片派生到我的代码片

  1. $ dwarfdump --uuid mobileguard.app/mobileguard  

2)查看xxx.dSYM的uuid。

[plain] view plaincopyprint?在CODE上查看代码片派生到我的代码片

  1. $ dwarfdump --uuid mobileguard.app.dSYM/Contents/Resources/DWARF/mobileguard  

3)xxx.crash。

上面两个UUID必须一样,而且必须跟Crash Log里面的UUID一致。打开Crash Log文件,在”Binary Images:”段中,YourApp后面的尖括号内的字符串就是UUID了。 
crash log uuid : armv7  <1dd5eb047491310f88cb7b1d7f61275c> /var/mobile/Applications/581404D9-FF06-455F-8251-846D41D18B40/

Note:

在这之前,需要找到对应的app和dSYM文件。这两个文件是在后缀为.archive的文件中,在我的机器(Mac OS 10.9.1,Xcode5.0.2)上,.archive文件在“/Users/mikelin/Library/Developer/Xcode/Archives/”文件夹下对应的日期文件夹中,也可以从Xcode > Organizer > Archive 下找到对应的Archive包。

确保三者uuid一致以后,用symbolicatecrash工具生成易读的日志信息。


首先找到symbollicatecrash工具在哪里:

find /Applications/Xcode.app -name symbolicatecrash -type f

你会找到:

/Applications/Xcode.app/Contents/SharedFrameworks/DTDeviceKitBase.framework/Versions/A/Resources/symbolicatecrash


方法一:使用.crash文件和dsym文件

先准备环境:

1)将symbolicatecrash文件拷贝到和那三个文件的同级目录,此方法不需要.app文件

2)设置xcode DEVELOPER_DIR。

[plain] view plaincopyprint?在CODE上查看代码片派生到我的代码片

  1. export DEVELOPER_DIR="/Applications/Xcode.app/Contents/Developer"  

然后执行命令:

[plain] view plaincopyprint?在CODE上查看代码片派生到我的代码片

  1. symbolicatecrash m.crash mobileguard.app.dSYM > n.crash  

转载:http://blog.csdn.net/jinzhu117/article/details/20615991


方法二:使用局部崩溃信息和.app文件

如果没有完整的.crash格式的崩溃文件,只有局部的崩溃信息,如下:

[plain] view plaincopyprint?在CODE上查看代码片派生到我的代码片

  1. Thread 0 Crashed:
    0   libobjc.A.dylib               0x00003ec0 objc_msgSend + 24
    1   MyApp                          0x000036d2 0×1000 + 9938 

其中:0x000036d2为栈地址,0×1000为偏移量

我们可以在控制台使用atos命令,解析出内存地址,此方法不需要.dsym文件

[plain] view plaincopyprint?在CODE上查看代码片派生到我的代码片

  1. atos -o MyApp.app/MyApp -arch arm64(崩溃日志中标明的架构) -l 0×1000(偏移量) 0x000036d2(栈地址) 
  2. 结果示例:__24-[MyApp initBase]_block_invoke.243 (in MyApp) (MyAppStart.m:286) 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/499914.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用maven的profile区分本地环境和线上环境

使用maven的profile区分本地环境和线上环境 多环境开发&#xff0c;使用maven-profile&#xff0c;就可以在打包的时候通过参数的调整&#xff0c;最终打的包也不同。 以区分本地数据库和线上数据库为例 比如测试环境&#xff0c;用的是本地测试数据库&#xff1b;生产环境用…

查看函数库.a函数符号信息

一、概述 nm命令可以列出一个函数库文件中的符号表。它对于静态的函数库和共享的函数库都起作用。对于一个给定的函数库&#xff0c;nm命令可以列出函数库中定义的所有符号&#xff0c;包括每个符号的值和类型。还可以给出在原程序中这个函数&#xff08;符号&#xff09;是在多…

重构,体现一个工程师的基本素养和底蕴(细节篇)

重构小记&#xff08;重构&#xff0c;改善既有代码的设计读后总结&#xff09; 方法级别 提炼函数&#xff1a; 将一个大方法&#xff0c;拆成多个小方法&#xff0c;难点在于小方法的命名。 假如有早上上学的一个大方法&#xff0c; 那么就应该在里面有起床&#xff0c;穿衣…

MVPVM模式介绍

一、概述MVPVM即&#xff1a;Model-View-Presenter-ViewModel。此模式是MVVM和MVP模式的结合体。但是交互模式发生了比较大的变化。MVVM参考本博客文章&#xff1a;iOS-MVVM-模式介绍MVP参考本博客文章&#xff1a;MVP模式介绍 二、原理&#xff1a;Presenter同时持有View、Mod…

[线程池] ------ 形象的描述线程池,用一个特好记的例子来记忆

线程池 为了减少线程频繁的创建和销毁过程&#xff0c;引入池的概念。 将一些线程先创建好放在线程池中&#xff0c;每次来任务就用池中的线程执行&#xff0c;空闲时池中线程就等待&#xff0c;但不销毁。 原始线程池的创建&#xff1a; ThreadPoolExecutor executor1 new …

分组密码的工作模式

一、理论基础1.概述密码学中&#xff0c;块密码的工作模式允许使用同一个块密码密钥对多于一块的数据进行加密&#xff0c;并保证其安全性。块密码自身只能加密长度等于密码块长度的单块数据&#xff0c;若要加密变长数据&#xff0c;则数据必须先被划分为一些单独的密码块。通…

数据仓库基本认知

数据仓库概念&#xff1a; 数据仓库&#xff0c;英文名称Data Warehouse&#xff0c;简写为DW。 是一种面向分析的存储系统。 他是一个很大的数据存储集合&#xff0c;出于企业的分析性报告和决策支持目的而创建&#xff0c;对多样的业务数据进行筛选与整合。 它为企业提供一…

PBOC3.0中使用的国密SM2算法

一、知识准备 PBOC3.0规范就是《中国金融集成电路&#xff08;IC&#xff09;卡规范》3.0版本。SM2是国密局推出的一种他们自己说具有自主知识产权的非对称商用密码算法。本身是基于ECC椭圆曲线算法的&#xff0c;所以要讲SM2, 先要弄懂ECC。 完全理解ECC算法需要一定的数学功底…

mapper注入失败,NoSuchBeanDefinitionException: No qualifying bean of type [com.xxx.XxxMapper] found for d

mapper注入失败: Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.xxx.XxxMapper] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependen…

战地体能训练模拟器

一、名称&#xff1a;战地体能训练模拟器二、整体介绍&#xff1a; 1.体验者身处一个封闭空间的正中央&#xff0c;空间内部表面全部附着显示器&#xff0c;包含地板(因为地板是平的&#xff0c;可以使用投影的方式实现)&#xff0c;经过视角上的设计&#xff0c;体验者就像身处…

java读文件写文件

使用了try-with-resource语法&#xff08;JDK1.7及以上&#xff09;&#xff0c;代码更加便捷 Junit测试样例&#xff0c;先写入文件&#xff0c;再读出来&#xff1a; RunWith(SpringJUnit4ClassRunner.class) ContextConfiguration(locations "classpath:spring-conf…

Markdown入门

Markdown 是一种轻量级的「标记语言」&#xff0c;它的优点很多&#xff0c;目前也被越来越多的写作爱好者&#xff0c;撰稿者广泛使用。看到这里请不要被「标记」、「语言」所迷惑&#xff0c;Markdown 的语法十分简单。常用的标记符号也不超过十个&#xff0c;这种相对于更为…

bean注入失败的几种情况和解决思路:NoSuchBeanDefinitionException: No qualifying bean of type

bean注入失败&#xff0c;无非是两种情况&#xff0c;要么注入的写法出错&#xff0c;要么被注入的Bean未定义。 1.Bean未定义 如果是直接在XML中配置bean标签的时候 检查id和class是否写对 如果是用注解形式申明Bean 先检查Controller、Service、Repository、 Component …

通过AVFoundation框架获取摄像头数据

一、概述 从iOS4开始&#xff0c;AVFoundation框架增加了几个类&#xff0c;AVCaptureDevice、AVCaptureSession等&#xff0c;可以获取摄像头的数据&#xff0c;而不会弹出类似于ImagePicker一样的界面&#xff0c;我们可以将数据转为一张张的图片&#xff0c;然后我们可以即时…

mysql数据库支持emoji表情的详解

mysql存储emoji表情的时候&#xff0c;就会报错&#xff0c;如下&#xff1a; Error updating database. Cause: java.sql.SQLException: Incorrect string value: ‘\xF0\x9F\x98\x8A\xF0\x9F…’ for column ‘这是我表中的字段’ at row 1 初步定位是我的数据库是utf8编码…

CoreText使用介绍

一、概述 1.CoreText是苹果创建的一个用于文字排版的框架&#xff0c;可以实现文字排版、图文混排等复杂的界面效果。从iOS3.2启用。2.一个开源工具类-OHAttributedLabel&#xff0c;就是使用CoreText框架实现的&#xff0c;能够实现一个Label中有不同的文字大小、文字颜色、字…

编程规范:长函数的思考

在工作&#xff0c;我们应该都不想看到非常的长函数。对于一个运行5年左右的项目&#xff0c;极有可能出现这种情况。由于长函数的长、if/else嵌套&#xff0c;导致代码的可读性非常差&#xff0c;这对于项目的维护和开发带来了极大的困难。所以我们应该避免写长函数&#xff0…

用redis实现延迟队列

现在在用的redis实现延迟队列的主流程

iPhone各版本屏幕尺寸

设备宽高对角线逻辑分辨率(point)Scale Factor设备分辨率(pixel)PPI iPhoneWidthHeightDiagonal 3GS2.4 inches (62.1 mm)4.5 inches (115.5 mm)3.5-inch320x4801x320x480163 4(s)2.31 inches (58.6 mm)4.5 inches (115.2 mm)3.5-inch320x4802x640x960326 5c2.33 inches (59.2…

maven更新快照不起作用的解决方法

问题&#xff1a;maven的快照包更新后&#xff0c;调用方使用idea点下面这个地方更新maven&#xff0c;并没有拉到最新的快照 解决方法1 删除本地仓库的快照包&#xff0c;再重新拉一次 解决方法2 下图&#xff0c;这里点进去 下图&#xff0c;这个勾上就行了&#xff0c;再…