最近一段时间一直忙于开发新平台系统的功能,今天测试那边拿过来简单的测试一下,并对相关需求和功能点进行验证。结果出现了一个奇怪的问题:在验证某个功能点时,在release模式下的程序频繁出现奔溃现象。之前在开发该功能点时也进行了充分的测试,程序一直运行正常,怎么一到release模式下就出现频繁奔溃的现象呢?
由于还在新功能的开发过程中,本想测试中的小问题可以留到后面正式测试时再解决,毕竟时间点比较紧,实现既定的功能是第一位的。但是对于这种频繁奔溃的问题,测试那边肯定很是恼火的,就连我自己也看不过去了,时间再紧也得先解决这个问题。于是,仔细走读了上述功能点的代码,也没发现什么问题,而且要命的是debug下没有发生奔溃的问题。其实也知道,这可能是与程序在debug下和release下的不同特性导致的,比如:变量在debug下即使没有初始化,编译器也会去初始化,而在release下则不会,会使用随机值;debug下有大量调试信息,有内存保护,出现奔溃的几率要小一点,而release下却没有这样的保护。 本来在程序中植入了华生医生,以便在程序出现异常时利用华生医生产生的日志文件,结合IDA工具对异常点进行定位。但是不幸的是,在出现奔溃的时候并没有产生日志文件,这样就比较棘手了。由于debug下很难复现,release下又没有奔溃日志,加上系统的代码量很大,只能修改工程在release下配置,在release下进行调试了。结果在release下调试很快找到了问题,问题在于某行代码对空指针操作了。那么既然是空指针,那么debug下和release下的截然不同的表现作何解释呢?出问题的代码与上述功能点没直接的联系