xcode release 和 debug 模式造成的不同
来源:互联网 发布:淘宝鞋子女款 编辑:程序博客网 时间:2024/04/28 13:49
============================================================
博文原创,转载请声明出处
电子咖啡(原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不包含任何调试信息,所以体积小、运行速度快。
说一下我这次遇到的错误:
代码是一段循环,错误原因是我数组越界了
- int emojiRangeArray[12] = {0,10,20,30,40,50,60,70,80,90,100,104};
- for (int j = 0 ; j<12 ; j++ ) {
- int startIndex = emojiRangeArray[j];
- int endIndex = emojiRangeArray[j+1]; //【1】、这里j最大是11,所以j+1是12,越界了
- printf("showEmojiView---startIndex: %d, endIndex: %d\n",startIndex,endIndex);
- for (int i = startIndex ; i<= endIndex ; i++ ) { //【2】、这里由于上面越界,这里提供的数值不对,所以内部NSArray objectAtIndex调用时候越界了
但是在release中,emojiRangeArray[12]=1094795585(应该是内存地址),大于于startIndex,【2】处条件符合,继续循环,触发了exception。
- xcode release 和 debug 模式造成的不同
- xcode release 和 debug 模式造成的不同
- ios开发答疑录系列---xcode release 和 debug 模式造成的不同
- ios开发答疑录系列---xcode release 和 debug 模式造成的不同
- ios开发答疑录系列---xcode release 和 debug 模式造成的不同
- Xcode使用六:Xcode的debug和release模式
- xcode debug模式和release模式的设置
- 使用Xcode DEBUG模式和RELEASE模式
- 使用Xcode-debug模式和release模式
- 使用Xcode DEBUG模式和RELEASE模式
- vs2005下debug模式和release模式的不同
- Debug和Release模式下加载不同的库文件
- Opencv在Release和Debug不同模式下的配置
- Release和Debug模式的区别以及Opencv在Release和Debug不同模式下的配置
- xcode 里的release 和 debug 区别
- Xcode中Release和Debug的区别
- vc中debug和release的不同
- vc中debug 和release的不同
- iOS app在itunesConnect里面的几种状态之解析
- yc
- C++中delete和delete[]的区别
- (11)冒泡排序
- oracle日期相减
- xcode release 和 debug 模式造成的不同
- vim窗口分割的操作方法
- (Android开发技巧系列)创建公用组件和在新应用中调用组件
- php (二十)常用正则表达式
- java 读写文件,配置文件的写法
- FREERTOS之任务创建删除
- js 实现菜单左右滚动显示
- java发送Email,带附件
- 有些.php或者.java无法执行crontab脚本问题