热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

debug下情况良好、release下频繁奔溃问题的跟踪与解析

最近一段时间一直忙于开发新平台系统的功能,今天测试那边拿过来简单的测试一下,并对相关需求和功能点进行验证。结果出现了一个奇怪的问题:在验证某个功能点时,在release模式下的程

        最近一段时间一直忙于开发新平台系统的功能,今天测试那边拿过来简单的测试一下,并对相关需求和功能点进行验证。结果出现了一个奇怪的问题:在验证某个功能点时,在release模式下的程序频繁出现奔溃现象。之前在开发该功能点时也进行了充分的测试,程序一直运行正常,怎么一到release模式下就出现频繁奔溃的现象呢?

        由于还在新功能的开发过程中,本想测试中的小问题可以留到后面正式测试时再解决,毕竟时间点比较紧,实现既定的功能是第一位的。但是对于这种频繁奔溃的问题,测试那边肯定很是恼火的,就连我自己也看不过去了,时间再紧也得先解决这个问题。于是,仔细走读了上述功能点的代码,也没发现什么问题,而且要命的是debug下没有发生奔溃的问题。其实也知道,这可能是与程序在debug下和release下的不同特性导致的,比如:变量在debug下即使没有初始化,编译器也会去初始化,而在release下则不会,会使用随机值;debug下有大量调试信息,有内存保护,出现奔溃的几率要小一点,而release下却没有这样的保护。  本来在程序中植入了华生医生,以便在程序出现异常时利用华生医生产生的日志文件,结合IDA工具对异常点进行定位。但是不幸的是,在出现奔溃的时候并没有产生日志文件,这样就比较棘手了。由于debug下很难复现,release下又没有奔溃日志,加上系统的代码量很大,只能修改工程在release下配置,在release下进行调试了。结果在release下调试很快找到了问题,问题在于某行代码对空指针操作了。那么既然是空指针,那么debug下和release下的截然不同的表现作何解释呢?出问题的代码与上述功能点没直接的联系,于是找到相关责任同事,让其查一下其负责的模块,怎么出现了对空指针操作的情况。待找到可能的出错的代码点时,我过去看了一下,结果终于可以真相大白了:同事定义的变量,由于使用了if判断语句导致if内的语句没有执行导致变量没有初始化,在debug下没问题,因为编译器会对该变量初始化,而在release下变量中存放就是随机值了,导致接下来的if判断语句条件为真,进入了出错的函数中去了,从而导致程序的奔溃(在出错的函数中并没有对指针进行是否为NULL的判断)。这就很好解释了为什么程序在debug下和release下的不同表现了。

        花了很大的精力才最终解决上面的问题。从中我们也能总结一些东西:平时写代码一定要规范,变量一定要初始化,指针变量要做是否为NULL的判断等等。由于这个同事是刚毕业的,编码经验相对比较少,一方面代码不够规范,另外代码没有进行仔细的走读才导致了上面的问题。所以,我们平时还是要多强调编码的规范性,特别是对刚毕业的新同事,应该更要强调这一点,因为规范性在提高代码可读性的同时,也可以减少代码出错的几率。这点在大型系统的开发中也尤为重要。

       下面给出在VC6.0中如何在release模式下进行调试的办法。只要在工程的C++ tab页面和Link tab页面中进行如下的配置就可以了。

       1、在C++ tab页面中:

             category:General  

             Optimizations:Disable(Debug)

             Debug info: program database

             如下所示:

            

       2、在Link tab页面中:

             category:General  

             勾选 General debug info

             勾选 General mapfile

             如下所示:

            





推荐阅读
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了Perl的测试框架Test::Base,它是一个数据驱动的测试框架,可以自动进行单元测试,省去手工编写测试程序的麻烦。与Test::More完全兼容,使用方法简单。以plural函数为例,展示了Test::Base的使用方法。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 拥抱Android Design Support Library新变化(导航视图、悬浮ActionBar)
    转载请注明明桑AndroidAndroid5.0Loollipop作为Android最重要的版本之一,为我们带来了全新的界面风格和设计语言。看起来很受欢迎࿰ ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
  • C++字符字符串处理及字符集编码方案
    本文介绍了C++中字符字符串处理的问题,并详细解释了字符集编码方案,包括UNICODE、Windows apps采用的UTF-16编码、ASCII、SBCS和DBCS编码方案。同时说明了ANSI C标准和Windows中的字符/字符串数据类型实现。文章还提到了在编译时需要定义UNICODE宏以支持unicode编码,否则将使用windows code page编译。最后,给出了相关的头文件和数据类型定义。 ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
author-avatar
猪可夫司机
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有