今天想试试用dsym和crash文件跟踪crash信息,可是一直返回如下信息:

Thread  name:  Dispatch queue: com.apple.main-thread
Thread Crashed:
libsystem_kernel.dylib 0x23269c84 __pthread_kill +
libsystem_pthread.dylib 0x2330bb46 pthread_kill +
libsystem_c.dylib 0x232000c4 abort +
libc++abi.dylib 0x22d7a7dc __cxa_bad_cast +
libc++abi.dylib 0x22d936a0 default_unexpected_handler() +
libobjc.A.dylib 0x22d9f098 _objc_terminate() +
libc++abi.dylib 0x22d90e16 std::__terminate(void (*)()) +
libc++abi.dylib 0x22d905f4 __cxxabiv1::exception_cleanup_func(_Unwind_Reason_Code, _Unwind_Exception*) +
libobjc.A.dylib 0x22d9eed2 objc_exception_throw +
CoreFoundation 0x234e831e -[__NSArrayI objectAtIndex:] +
test 0x000791f2 __hidden#5_ (__hidden#43_:35)
libdispatch.dylib 0x2316fdd6 _dispatch_call_block_and_release +
libdispatch.dylib 0x231794e6 _dispatch_after_timer_callback +
libdispatch.dylib 0x2316fdc2 _dispatch_client_callout +
libdispatch.dylib 0x231826d2 _dispatch_source_latch_and_call +
libdispatch.dylib 0x23171d16 _dispatch_source_invoke +
libdispatch.dylib 0x231741fe _dispatch_main_queue_callback_4CF +
CoreFoundation 0x23594fc4 __CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE__ +
CoreFoundation 0x235934be __CFRunLoopRun +
CoreFoundation 0x234e5bb8 CFRunLoopRunSpecific +
CoreFoundation 0x234e59ac CFRunLoopRunInMode +
GraphicsServices 0x2475faf8 GSEventRunModal +
UIKit 0x277d1fb4 UIApplicationMain +
test 0x000797de main (__hidden#317_:)
libdyld.dylib 0x23198872 start +

确实是解析了不假,但是却只能得到

test                              0x000791f2 __hidden#5_ (__hidden#43_:35)
这个35是对的,的确是源文件第35行出了bug,但是,
hidden是什么东西?之后我又单独查看了这个dsym文件,内容如下:
----------------------------------------------------------------------
File: /Users/Breeze/Desktop/crash/test.app.dSYM/Contents/Resources/DWARF/test (armv7)
----------------------------------------------------------------------
.debug_info contents: 0x00000000: Compile Unit: length = 0x00000073 version = 0x0002 abbr_offset = 0x00000000 addr_size = 0x04 (next CU at 0x00000077) 0x0000000b: TAG_compile_unit [] *
AT_producer( "__hidden#30_" )
AT_language( DW_LANG_ObjC )
AT_name( "__hidden#43_" )
AT_stmt_list( 0x00000000 )
AT_comp_dir( "__hidden#41_" )
AT_APPLE_optimized( 0x01 )
AT_APPLE_major_runtime_vers( 0x02 )
AT_low_pc( 0x0000a0b0 )
AT_high_pc( 0x0000a206 ) 0x00000028: TAG_subprogram []
AT_low_pc( 0x0000a0b0 )
AT_high_pc( 0x0000a154 )
AT_name( "__hidden#45_" ) 0x00000035: TAG_subprogram []
AT_low_pc( 0x0000a154 )
AT_high_pc( 0x0000a166 )
AT_name( "__hidden#1_" ) 0x00000042: TAG_subprogram []
AT_low_pc( 0x0000a168 )
AT_high_pc( 0x0000a16e )
AT_name( "__hidden#2_" ) 0x0000004f: TAG_subprogram []
AT_low_pc( 0x0000a170 )
AT_high_pc( 0x0000a176 )
AT_name( "__hidden#3_" ) 0x0000005c: TAG_subprogram []
AT_low_pc( 0x0000a178 )
AT_high_pc( 0x0000a1a4 )
AT_name( "__hidden#44_" ) 0x00000069: TAG_subprogram []
AT_low_pc( 0x0000a1a4 )
AT_high_pc( 0x0000a206 )
AT_name( "__hidden#42_" ) 0x00000076: NULL 0x00000077: Compile Unit: length = 0x000000db version = 0x0002 abbr_offset = 0x00000000 addr_size = 0x04 (next CU at 0x00000156) 0x00000082: TAG_compile_unit [] *
AT_producer( "__hidden#30_" )
AT_language( DW_LANG_ObjC )
AT_name( "__hidden#301_" )
AT_stmt_list( 0x000000bf )
AT_comp_dir( "__hidden#41_" )
AT_APPLE_optimized( 0x01 )
AT_APPLE_major_runtime_vers( 0x02 )
AT_low_pc( 0x0000a208 )
AT_high_pc( 0x0000a796 ) 0x0000009f: TAG_subprogram []
AT_low_pc( 0x0000a208 )
AT_high_pc( 0x0000a20c )
AT_name( "__hidden#315_" ) 0x000000ac: TAG_subprogram []
AT_low_pc( 0x0000a20c )
AT_high_pc( 0x0000a20e )
AT_name( "__hidden#314_" ) 0x000000b9: TAG_subprogram []
AT_low_pc( 0x0000a210 )
AT_high_pc( 0x0000a212 )
AT_name( "__hidden#313_" ) 0x000000c6: TAG_subprogram []
AT_low_pc( 0x0000a214 )
AT_high_pc( 0x0000a216 )
AT_name( "__hidden#312_" ) 0x000000d3: TAG_subprogram []
AT_low_pc( 0x0000a218 )
AT_high_pc( 0x0000a21a )
AT_name( "__hidden#311_" ) 0x000000e0: TAG_subprogram []
AT_low_pc( 0x0000a21c )
AT_high_pc( 0x0000a22c )
AT_name( "__hidden#310_" ) 0x000000ed: TAG_subprogram []
AT_low_pc( 0x0000a22c )
AT_high_pc( 0x0000a2a2 )
AT_name( "__hidden#309_" ) 0x000000fa: TAG_subprogram []
AT_low_pc( 0x0000a2a4 )
AT_high_pc( 0x0000a372 )
AT_name( "__hidden#308_" ) 0x00000107: TAG_subprogram []
AT_low_pc( 0x0000a374 )
AT_high_pc( 0x0000a5b6 )
AT_name( "__hidden#307_" ) 0x00000114: TAG_subprogram []
AT_low_pc( 0x0000a5b8 )
AT_high_pc( 0x0000a65c )
AT_name( "__hidden#306_" ) 0x00000121: TAG_subprogram []
AT_low_pc( 0x0000a65c )
AT_high_pc( 0x0000a702 )
AT_name( "__hidden#305_" ) 0x0000012e: TAG_subprogram []
AT_low_pc( 0x0000a704 )
AT_high_pc( 0x0000a714 )
AT_name( "__hidden#304_" ) 0x0000013b: TAG_subprogram []
AT_low_pc( 0x0000a714 )
AT_high_pc( 0x0000a73a )
AT_name( "__hidden#302_" ) 0x00000148: TAG_subprogram []
AT_low_pc( 0x0000a73c )
AT_high_pc( 0x0000a796 )
AT_name( "__hidden#300_" ) 0x00000155: NULL 0x00000156: Compile Unit: length = 0x00000032 version = 0x0002 abbr_offset = 0x00000000 addr_size = 0x04 (next CU at 0x0000018c) 0x00000161: TAG_compile_unit [] *
AT_producer( "__hidden#30_" )
AT_language( DW_LANG_ObjC )
AT_name( "__hidden#317_" )
AT_stmt_list( 0x00000320 )
AT_comp_dir( "__hidden#41_" )
AT_APPLE_optimized( 0x01 )
AT_APPLE_major_runtime_vers( 0x02 )
AT_low_pc( 0x0000a798 )
AT_high_pc( 0x0000a7f4 ) 0x0000017e: TAG_subprogram []
AT_low_pc( 0x0000a798 )
AT_high_pc( 0x0000a7f4 )
AT_name( "__hidden#316_" ) 0x0000018b: NULL

竟然全部都是hidden!!

原来是我在用orgenizer 导出ipa时,使用了下图选项:

注意到这个 rebuild from bitcode 选项了吗?看看说明:

我选择了这个选项,之后使用导出的ipa和相应的dysm文件进行相应的操作,我们可以比较一下选和不选这个选项得到不同dysm的文件大小:

上边2个是使用 bitcode发布选项后,出现的dsym,每个之后12K。而下面那个是不使用的dsym,有2.1M。

之后查看了其他网页,有如下资料:

如果你的应用也准备启用Bitcode编译机制,就需要注意以下几点:

· Xcode 7默认开启Bitcode,如果应用开启Bitcode,那么其集成的其他第三方库也需要是Bitcode编译的包才能真正进行Bitcode编译

· 开启Bitcode编译后,编译产生的.app体积会变大(中间代码,不是用户下载的包),且.dSYM文件不能用来崩溃日志的符号化(用户下载的包是Apple服务重新编译产生的,有产生新的符号文件)

· 通过Archive方式上传AppStore的包,可以在Xcode的Organizer工具中下载对应安装包的新的符号文件              

就是说,发布时可以模拟appstore的bitcode功能,但是为什么有2个 dsym文件,而只有一个ipa文件呢?难道这个ipa文件会根据不同的机器安装成不同的2进制文件?有这么智能?

ios bitcode 机制对 dsym 调试文件的影响的更多相关文章

  1. iOS开发系列-iOS签名机制

    概述 想要了解iOS的签名机制需要有一定密码学有一定的了解.下面依次介绍的数据的加密解密.单向散列函数.数字签名.证书.iOS签名机制. 数据加密解密 在网络通信中想要防止数据被攻击者拦截,我们通常对 ...

  2. 【转】iOS开发Xcode7真机调试教程

    原文网址:https://www.skyfox.org/ios-xcode7-debug-device.html 从Xcode7开始,Xcode 不需要$99/$299升级开发者直接可以进行真机调试 ...

  3. iOS开发之Xcode常用调试技巧总结

    转载自:iOS开发之Xcode常用调试技巧总结 最近在面试,面试过程中问到了一些Xcode常用的调试技巧问题.平常开发过程中用的还挺顺手的,但你要突然让我说,确实一脸懵逼.Debug的技巧很多,比如最 ...

  4. ios消息机制

    ios消息机制介绍 ios 调用每一个方法的时候其实是走的ios的消息机制 举例介绍一下 创建一个Pserson类 有一个eat 对象方法 那么下面的代码可以用消息机制实现  导入消息头文件    # ...

  5. iOS签名机制解析

    最近遇到一个签名的问题,借机把iOS签名相关知识点研究了一下.现总结如下:(研究过程中参考了这位仁兄的博客.很全面,本文也有部分借鉴) 非对称加密 这个是签名机制的算法基础.所谓非对称加密的是相对于对 ...

  6. iOS推送证书转pem文件

    iOS推送证书转 .pem文件. 推送证书转pem文件openssl x509 -in apns_miaobozhibo.cer -inform der -out apns_miaobozhibo.p ...

  7. IOS 消息机制(NSNotificationCenter)

    消息机制 NSNotificationCenter 一直都在频繁使用,但是却对其原理不是十分了解.今天就花些时间,把消息机制原理重头到尾好好过一遍. iOS 提供了一种 "同步的" ...

  8. iOS开发拓展篇—封装音频文件播放工具类

    iOS开发拓展篇—封装音频文件播放工具类 一.简单说明 1.关于音乐播放的简单说明 (1)音乐播放用到一个叫做AVAudioPlayer的类 (2)AVAudioPlayer常用方法 加载音乐文件 - ...

  9. iOS事件机制(二)

    从上一篇的内容我们知道,在iOS中一个事件用一个UIEvent对象表示,UITouch用来表示一次对屏幕的操作动作,由多个UITouch对象构成了一个UIEvent对象.另外,UIResponder是 ...

随机推荐

  1. Method Swizzling (方法调配)

    Method Swizzling是改变一个selector的实际实现的技术.通过这一技术,我们可以在运行时通过修改类的分发表中selector对应的函数,来修改方法的实现. 例如,我们想跟踪在程序中每 ...

  2. ASP.NET MVC 自己实现登陆验证过滤器

    1.首先添加一个过滤器类,并实现接口中对应的方法 public class YLFAuthorizeAttribute : FilterAttribute, IAuthorizationFilter ...

  3. 【转载】 C中的access函数

    分类: C/C++ int   access(const   char   *filename,   int   amode); amode参数为0时表示检查文件的存在性,如果文件存在,返回0,不存在 ...

  4. VMnet1和V8

    vmware默认使用了两个虚拟网卡: vmnet1 v1 vmnet8 v8 vmnet1是host-only,也就是说,选择用vmnet1的话就相当于VMware给你提供了一个虚拟交换机,仅将虚拟机 ...

  5. R获取股票数据

    R中好几个Pkg都提供了股票数据的在线下载方法,如果非得在其中找出一个最好的,那么quantmod当之无愧!举一个例子,譬如下载沪市大盘数据,代码可以是: library(quantmod)SSE & ...

  6. Emoji表情符号录入MySQL数据库报错的解决方案(MySQL utf8与utf8mb4区别)

    本文转自:http://blog.itpub.net/26230597/viewspace-1243233/前言:手机app应用评论的时候,恢复表情符号,提示失败. 1,查看tomcat后台日志,核心 ...

  7. javascript位运算

    javascript作为一门高级语言,他尽量让开发人员减少思考底层的硬件工作原理,而将精力集中在逻辑开发的层面.不过,不论这门语言多么高级,我们必须知道数据依然以bits的形式存储,有时候我们会直接与 ...

  8. Update-Package : Unable to load the service index for source https://api.nuget.org/v3/index.json.

    由于更改了项目"属性"的"目标框架"(原来的框架是".NET Frameword4.5"改为了".NET Frameword4&q ...

  9. 【Solr】copy字段的应用

    目录 界面查询应用 熟悉Schema.xml copy域的应用 回到顶部 界面查询应用 添加一个文档 查询添加的文档 以上详细介绍了query里面的参数详解. 当不输入任何条件时,进行查询,看看返回结 ...

  10. jekyll 安装过程

    如果有, linux以源码包方式发布, 方便,快捷, 容易出错,安装内容难找到,版本容易冲突.兼容性会出错.如何解决这种方式:1.上网查找答案,你遇到的别人也有,关键词匹配到,好像没有别的办法解决了, ...