时间2013-08-20 12:49:20 GoWhich原文  http://www.gowhich.com/blog/view/id/343

苹果官方 Crash文件分析方法 (iOS系统Crash文件分析方法)

symbolicatecrash路径:/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DTDeviceKitBase.framework/Versions/A/Resources/symbolicatecrash

对于提交的苹果官方的app,在审核的时候会给我们一些crash文件,对于这些有用的文件,里面是关于我们的bug的一些信息,那么该如何去调试呢 
第一步:在任意目录创建一个目录,用来调试crash,我这里创建一个crash目录 
第二步:将之前Archive的文件copy到crash目录里面

其中包括两个文件.app和.app.dSYM

如果找不到的话可以按照下面的步骤进行

先到Organizer

1,找到提交那个时刻的Archive文件,选中,show in Finder

2,然后到达这里,然后再选中红色区域,会出现3中所示的提示

3,ok显示包内容,然后自己找找吧,肯定会有的

copy就好了

第三步:将symbolicatecrash工具copy到crash目录

找不到这个文件可以去

/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DTDeviceKit.framework/Versions/A/Resources

这里看看,应该就会有了。

第四步:将要调试的crash文件copy到crash目录

这个crash文件,这里是来自苹果官方的,其实有时候也是来自其他的用户的电脑上的。 
第五步:通过命令进行测试 
打开终端,转到crash目录 
执行如下命令:

./symbolicatecrash ./2013-08-16-035933_DLiPad.crash ./appname.app.dSYM > symbol.crash
cat ./symbol.crash

结果如下:

Incident Identifier: 5434D911-E207-4D79-9139-40EA4EA76B45
CrashReporter Key:   d11ed3a4adbb0d9ca4d6016e73e439640f95f289
Hardware Model:      xxx
Process:         appname [8158]
Path:            /var/mobile/Applications/2AB1E8EB-6ECE-44F4-8195-4042339DD359/appname.app/appname
Identifier:      appname
Version:         ??? (???)
Code Type:       ARM (Native)
Parent Process:  launchd [1] Date/Time:       2013-08-16 03:59:33.513 +0800
OS Version:      iOS 6.1.3 (10B329)
Report Version:  104 Exception Type:  EXC_CRASH (SIGABRT)
Exception Codes: 0x0000000000000000, 0x0000000000000000
Crashed Thread:  0 Last Exception Backtrace:
0   CoreFoundation                    0x3126029e 0x3119e000 + 795294
1   libobjc.A.dylib               0x3910497a 0x390fc000 + 35194
2   UIKit                         0x333f537c 0x33065000 + 3736444
3   UIKit                         0x3323758e 0x33065000 + 1910158
4   UIKit                         0x330c079c 0x33065000 + 374684
5   UIKit                         0x33068c34 0x33065000 + 15412
6   UIKit                         0x330686c8 0x33065000 + 14024
7   UIKit                         0x33068116 0x33065000 + 12566
8   GraphicsServices                  0x34d5c59e 0x34d56000 + 26014
9   GraphicsServices                  0x34d5c1ce 0x34d56000 + 25038
10  CoreFoundation                    0x3123516e 0x3119e000 + 618862
11  CoreFoundation                    0x31235112 0x3119e000 + 618770
12  CoreFoundation                    0x31233f94 0x3119e000 + 614292
13  CoreFoundation                    0x311a6eb8 0x3119e000 + 36536
14  CoreFoundation                    0x311a6d44 0x3119e000 + 36164
15  UIKit                         0x330bf480 0x33065000 + 369792
16  UIKit                         0x330bc2fc 0x33065000 + 357116
17  appname                            0x000cf358 0xce000 + 4952
18  libdyld.dylib                 0x3953bb1c 0x3953a000 + 6940 Thread 0 name:  Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0   libsystem_kernel.dylib            0x39602350 __pthread_kill + 8
1   libsystem_c.dylib             0x3957911e pthread_kill + 54
2   libsystem_c.dylib             0x395b596e abort + 90
3   libc++abi.dylib               0x38b53d4a abort_message + 70
4   libc++abi.dylib               0x38b50ff4 default_terminate() + 20
5   libobjc.A.dylib               0x39104a74 _objc_terminate() + 144
6   libc++abi.dylib               0x38b51078 safe_handler_caller(void (*)()) + 76
7   libc++abi.dylib               0x38b51110 std::terminate() + 16
8   libc++abi.dylib               0x38b52594 __cxa_rethrow + 84
9   libobjc.A.dylib               0x391049cc objc_exception_rethrow + 8
10  CoreFoundation                    0x311a6f1c CFRunLoopRunSpecific + 452
11  CoreFoundation                    0x311a6d44 CFRunLoopRunInMode + 100
12  UIKit                         0x330bf480 -[UIApplication _run] + 664
13  UIKit                         0x330bc2fc UIApplicationMain + 1116
14  appname                                0x000cf358 0xce000 + 4952
15  libdyld.dylib                 0x3953bb1c start + 0 Thread 1:
0   libsystem_kernel.dylib            0x39602d98 __workq_kernreturn + 8
1   libsystem_c.dylib             0x39550cf6 _pthread_workq_return + 14
2   libsystem_c.dylib             0x39550a12 _pthread_wqthread + 362
3   libsystem_c.dylib             0x395508a0 start_wqthread + 4 Thread 2 name:  Dispatch queue: com.apple.libdispatch-manager
Thread 2:
0   libsystem_kernel.dylib            0x395f2648 kevent64 + 24
1   libdispatch.dylib             0x39522974 _dispatch_mgr_invoke + 792
2   libdispatch.dylib             0x39522654 _dispatch_mgr_thread$VARIANT$mp + 32 Thread 3:
0   libsystem_kernel.dylib            0x39602d98 __workq_kernreturn + 8
1   libsystem_c.dylib             0x39550cf6 _pthread_workq_return + 14
2   libsystem_c.dylib             0x39550a12 _pthread_wqthread + 362
3   libsystem_c.dylib             0x395508a0 start_wqthread + 4 Thread 4 name:  WebThread
Thread 4:
0   libsystem_kernel.dylib            0x395f1eb4 mach_msg_trap + 20
1   libsystem_kernel.dylib            0x395f2048 mach_msg + 36
2   CoreFoundation                    0x31235040 __CFRunLoopServiceMachPort + 124
3   CoreFoundation                    0x31233d9e __CFRunLoopRun + 878
4   CoreFoundation                    0x311a6eb8 CFRunLoopRunSpecific + 352
5   CoreFoundation                    0x311a6d44 CFRunLoopRunInMode + 100
6   WebCore                       0x37196500 RunWebThread(void*) + 440
7   libsystem_c.dylib             0x3955b30e _pthread_start + 306
8   libsystem_c.dylib             0x3955b1d4 thread_start + 4 Thread 0 crashed with ARM Thread State (32-bit):
    r0: 0x00000000    r1: 0x00000000      r2: 0x00000000      r3: 0x3b0f8534
    r4: 0x00000006    r5: 0x3b0f8b88      r6: 0x1d844f24      r7: 0x2fd329f4
    r8: 0x1d844f00    r9: 0x00000300     r10: 0x334de04b     r11: 0x1c535350
    ip: 0x00000148    sp: 0x2fd329e8      lr: 0x39579123      pc: 0x39602350
  cpsr: 0x00000010
......

再执行如下命令:

dwarfdump --lookup 0x000cf358 --arch armv7 appname.app.dSYM/

关键是在这里 0x000cf358 ,他是来自这里的

0   libsystem_kernel.dylib            0x39602350 __pthread_kill + 8 
1   libsystem_c.dylib             0x3957911e pthread_kill + 54 
2   libsystem_c.dylib             0x395b596e abort + 90 
3   libc++abi.dylib               0x38b53d4a abort_message + 70 
4   libc++abi.dylib               0x38b50ff4 default_terminate() + 20 
5   libobjc.A.dylib               0x39104a74 _objc_terminate() + 144 
6   libc++abi.dylib               0x38b51078 safe_handler_caller(void (*)()) + 76 
7   libc++abi.dylib               0x38b51110 std::terminate() + 16 
8   libc++abi.dylib               0x38b52594 __cxa_rethrow + 84 
9   libobjc.A.dylib               0x391049cc objc_exception_rethrow + 8 
10  CoreFoundation                    0x311a6f1c CFRunLoopRunSpecific + 452 
11  CoreFoundation                    0x311a6d44 CFRunLoopRunInMode + 100 
12  UIKit                         0x330bf480 -[UIApplication _run] + 664 
13  UIKit                         0x330bc2fc UIApplicationMain + 1116 
14  应用的名称                                0x000cf358 0xce000 + 4952 
15  libdyld.dylib                 0x3953bb1c start + 0

结果如下:

----------------------------------------------------------------------
 File: appname.app.dSYM/Contents/Resources/DWARF/appname (armv7)
----------------------------------------------------------------------
Looking up address: 0x00000000000cf358 in .debug_info... found! 0x0015d390:
 Compile Unit: length = 0x00001fc6  version = 0x0002  abbr_offset = 
0x00000000  addr_size = 0x04  (next CU at 0x0015f35a) 0x0015d39b: TAG_compile_unit [1] *
             AT_producer( "Apple LLVM version 4.2 (clang-425.0.24) (based on LLVM 3.2svn)" )
             AT_language( DW_LANG_ObjC )
             AT_name( "/Users/zhy/Downloads/ios/vlink_app_xunyi/xunYi7/library/ASIHttpRequest/ASIDownloadCache.m" )
             AT_low_pc( 0x000ccfc0 )
             AT_stmt_list( 0x0002cf0b )
             AT_comp_dir( "/Users/zhy/Downloads/ios/vlink_app_xunyi" )
             AT_APPLE_major_runtime_vers( 0x02 ) 0x0015dd38:     TAG_subprogram [53] *
                 AT_name( "-[ASIDownloadCache isCachedDataCurrentForRequest:]" )
                 AT_decl_file( "/Users/zhy/Downloads/ios/vlink_app_xunyi/xunYi7/library/ASIHttpRequest/ASIDownloadCache.m" )
                 AT_decl_line( 315 )
                 AT_prototyped( 0x01 )
                 AT_type( {0x0015d490} ( BOOL ) )
                 AT_APPLE_isa( 0x01 )
                 AT_low_pc( 0x000cf278 )
                 AT_high_pc( 0x000cf9e2 )
                 AT_frame_base( r7 )
                 AT_object_pointer( {0x0015dd54} ) 0x0015dd86:         TAG_lexical_block [10] *
                     AT_low_pc( 0x000cf2ca )
                     AT_high_pc( 0x000cf9de )
Line table dir : '/Users/zhy/Downloads/ios/vlink_app_xunyi/xunYi7/library/ASIHttpRequest'
Line table file: 'ASIDownloadCache.m' line 320, column 3 with start address 0x00000000000cf340 Looking up address: 0x00000000000cf358 in .debug_frame... found! 0x00007290: FDE
        length: 0x0000000c
   CIE_pointer: 0x00000000
    start_addr: 0x000cf278 -[ASIDownloadCache isCachedDataCurrentForRequest:]
    range_size: 0x0000076a (end_addr = 0x000cf9e2)
  Instructions: 0x000cf278: CFA=4294967295+4294967295

到这里就知道问题所在了吧

Line table dir : '/Users/zhy/Downloads/ios/vlink_app_xunyi/xunYi7/library/ASIHttpRequest'
Line table file: 'ASIDownloadCache.m' line 320, column 3 with start address 0x00000000000cf340

如果有多个crash文件的话,可以重复操作一遍就好了。

iOS 苹果官方 Crash文件分析方法 (iOS系统Crash文件分析方法)的更多相关文章

  1. iOS - 苹果官方Apple Pay开发文档(中文版)- Apple Pay(1)

    翻译自苹果官方Apple Pay开发文档.目前版本为1.0 概览: Apple Pay为用户从你的App里购买实际的物品和服务提供简单而安全的方法.通过Touch ID,用户可使用储存在iPhone ...

  2. iOS苹果官方Demo合集

    Mirror of Apple’s iOS samples This repository mirrors Apple’s iOS samples. Name Topic Framework Desc ...

  3. 苹果官方 Crash文件分析方法 (iOS系统Crash文件分析方法)

    对于提交的苹果官方的app,在审核的时候会给我们一些crash文件,对于这些有用的文件,里面是关于我们的bug的一些信息,那么该如何去调试呢 第一步:在任意目录创建一个目录,用来调试crash,我这里 ...

  4. 【转】 分析iOS Crash文件:符号化iOS Crash文件的3种方法

    当你的应用提交到AppStore或者各个渠道之后,请问你多久会拿到crash文件?你如何分析crash文件的呢? 上传crash文件 你的应用应当有模块能够在应用程序crash的时候上传crash信息 ...

  5. 分析iOS Crash文件:符号化iOS Crash文件的3种方法

    转自:http://www.cocoachina.com/industry/20140514/8418.html 转自wufawei的博客 当你的应用提交到App Store或者各个渠道之后,请问你多 ...

  6. 安装xcode6 beta 后调试出现Unable to boot the iOS Simulator以及编译苹果官方Swift的demo报错failed with exit code 1的解决的方法

    苹果昨天公布新语言Swift(雨燕),须要安装xcode6 以及mac os 系统为10.9以上. (xcode6 beta 可在官方下载.须要登录开发人员账号:mac os 系统直接更新就可以.在此 ...

  7. iOS数据存取---iOS-Apple苹果官方文档翻译

    CHENYILONG Blog iOS数据存取---iOS-Apple苹果官方文档翻译 数据存取/*技术博客http://www.cnblogs.com/ChenYilong/ 新浪微博http:// ...

  8. iOS网络基础---iOS-Apple苹果官方文档翻译

    CHENYILONG Blog iOS网络基础---iOS-Apple苹果官方文档翻译 iOS网络基础 技术博客http://www.cnblogs.com/ChenYilong/ 新浪微博http: ...

  9. iOS静态库 ---iOS-Apple苹果官方文档翻译

    iOS静态库 ---iOS-Apple苹果官方文档翻译 •什么是库? 库是共享程序代码的方式,一般分为静态库和动态库.静态库与动态库的区别? 静态库:链接时完整地拷贝至可执行文件中,被多次使⽤用就为什 ...

随机推荐

  1. Android第三方推送引擎比较

    所了解的第三方推送引擎有极光推送(JPush), 百度, 个推,腾讯信鸽等.根据了解,最专业的据说是极光推送,先看极光推送. 一.极光推送 https://www.jpush.cn/ 配置: 1.JP ...

  2. nodejs express route 的用法

    express 中文社区:http://expressjs.jser.us/community.html nodejs express route 的用法 1. 首先是最基本的用法. 1 2 3 4 ...

  3. python基础篇---实战---用户登入注册程序

    一.首先了解需求: 1.支持多个用户登入 2.登入成功后显示欢迎,并退出程序 3.登入三次失败后,退出程序,并在下次程序启动尝试登入时,该用户名依然是锁定状态 二.文件代码如下: f = open(& ...

  4. mongodb - 集合重命名

    #创建新的集合yb > for(i=0;i<10;i++){db.yb.insert({'i':i})} WriteResult({ "nInserted" : 1 } ...

  5. post请求方式的翻页爬取内容及思考

    1 #coding=utf-8 import urllib2 import urllib import json output = open('huizho.json', 'w') for page ...

  6. &lt;&lt;Python基础教程&gt;&gt;学习笔记 | 第11章 | 文件和素材

    打开文件 open(name[mode[,buffing]) name: 是强制选项,模式和缓冲是可选的 #假设文件不在.会报以下错误: >>> f = open(r'D:\text ...

  7. css - 当文本内容长度超出屏幕宽度时,以省略号代替

    <style> .ellipsis{ text-overflow: ellipsis; overflow: hidden; white-space: nowrap; } </styl ...

  8. 【进程线程与同步】5.4 System.Threading.Interlocked 为多个线程共享的变量提供原子操作

    using System; using System.Threading; internal class Program { private static long _counter = 1; pri ...

  9. poj1860--Currency Exchange

    Bellman-ford算法的反向应用--正循环检查 /** \brief poj 1860 Bellman-Ford * * \param date 2014/7/24 * \param state ...

  10. Atitit .h5文件上传

    Atitit .h5文件上传 1. 上传原理1 2. Html1 3. Js2 4. uploadV2.js2 5. upServlet & FileUploadService {3 6. 注 ...