现在的位置: 首页 > 综合 > 正文

xcode release 和 debug 模式造成的不同

2018年08月22日 ⁄ 综合 ⁄ 共 1190字 ⁄ 字号 评论关闭
============================================================
博文原创,转载请声明出处
电子咖啡(原id蓝岩)
============================================================

公司的应用在本地测试没有问题,于是提交到app store,审核通过后,自己下下来看看,去发现了一个crash。回到自己的mac上断点调试,正常。思考片刻,想起自己在本地开发是debug模式,而app store发布的是release模式,难道是两者的不同?于是我切换到release模式重新运行(切换方式如下图),报错。好吧,打断点找原因。却发现断电的log不打印,而且查看内存也是乱起八糟,疯掉。于是开始思考ios的debug和release有什么不同。

Release是发行版本,比Debug版本有一些优化,文件比Debug文件小 Debug是调试版本,Debug和Release调用两个不同的底层库。
一、"Debug是调试版本,包括的程序信息更多"
二、只有DEBUG版的程序才能设置断点、单步执行、使用TRACE/ASSERT等调试输出语句。
三、REALEASE不包含任何调试信息,所以体积小、运行速度快。

说一下我这次遇到的错误:

代码是一段循环,错误原因是我数组越界了

  1. int emojiRangeArray[12] = {0,10,20,30,40,50,60,70,80,90,100,104};  
  2.    for (int j = 0 ; j<12 ; j++ ) {  
  3.        int startIndex = emojiRangeArray[j];  
  4.        int endIndex = emojiRangeArray[j+1]; //【1】、这里j最大是11,所以j+1是12,越界了  
  5.        printf("showEmojiView---startIndex: %d, endIndex: %d\n",startIndex,endIndex);  
  6.        for (int i = startIndex ; i<= endIndex ; i++ ) { //【2】、这里由于上面越界,这里提供的数值不对,所以内部NSArray objectAtIndex调用时候越界了  

但是在debug中,emojiRangeArray[12]=12,小于startIndex,【2】处条件不符,循环结束,没有触发exception。

但是在release中,emojiRangeArray[12]=1094795585(应该是内存地址),大于于startIndex,【2】处条件符合,继续循环,触发了exception。

抱歉!评论已关闭.