博客
关于我
留意编译告警
阅读量:552 次
发布时间:2019-03-09

本文共 829 字,大约阅读时间需要 2 分钟。

在我参与过的一个项目中,我们增加了PcLint检查,但由于规则设置的缘故,有一个bug没有产生PcLint告警。在最终定位问题后,我们才发现它实际上已经导致了一个编译告警但被忽视,因为项目组没有要求代码必须清除所有告警。这个bug非常低级,是一个赋值时的精度丢失。具体代码如下:

nAvailPageFile = ullAvailPageFile;

前者是32位的int类型,后者是64位的DWORDLONG类型。编译器已经做出了提示,但却被忽视了:

warning C4244: “=”: 从“DWORDLONG”转换到“int”,可能丢失数据

也许你的工程中编译告警太多,由于破窗效应已经无暇顾及。但里面可能隐藏着bug,需要逐一排查把告警消除。这样当代码产生新的告警时才容易被发现。

当然,处理告警时同样得小心仔细。考虑下面这段代码:

DWORD dwBytes;char tmpBuf[BUF_SIZE];...

由于局部变量dwBytes没有被使用产生了一个告警:

warning C4101: “dwBytes”: 未引用的局部变量

如何消除这个告警呢?你的第一反应可能是把第一行dwBytes的定义注释掉。当然这是正确的做法。但也许注释掉以后再进行测试时,程序有可能会崩溃!原因如下:

有时候代码bug是“潜伏”的,往往两个bug在一起会相互抵消,不会暴露。当修改了其中一个bug后,另一个bug就暴露出来,导致程序异常。这里的另一个潜在问题是,代码中第二个局部变量tmpBuf在使用过程中可能存在内存越界,且越界的长度不多,刚好在4个字节范围内。当内存越界时,实际上使用了dwBytes变量所处的内存,而刚好dwBytes又没有被使用。因此程序运行平安无事。当dwBytes被注释掉以后,内存越界就踩到了函数的堆栈,堆栈被破坏后函数返回时,程序就崩溃了。因此每修改一行代码都需要充分评估修改前后的差异。留意编译告警,不要放过每一个潜在的问题。

转载地址:http://dkriz.baihongyu.com/

你可能感兴趣的文章
opencv图像分割2-GMM
查看>>
opencv图像分割3-分水岭方法
查看>>
opencv图像切割1-KMeans方法
查看>>
OpenCV图像处理篇之阈值操作函数
查看>>
opencv图像特征融合-seamlessClone
查看>>
OpenCV图像的深浅拷贝
查看>>
OpenCV在Google Colboratory中不起作用
查看>>
OpenCV学习(13) 细化算法(1)(转)
查看>>
OpenCV学习笔记(27)KAZE 算法原理与源码分析(一)非线性扩散滤波
查看>>
OpenCV学堂 | CV开发者必须懂的9种距离度量方法,内含欧氏距离、切比雪夫距离等(建议收藏)
查看>>
OpenCV学堂 | OpenCV中支持的人脸检测方法整理与汇总
查看>>
OpenCV学堂 | OpenCV案例 | 基于轮廓分析对象提取
查看>>
OpenCV学堂 | YOLOv8与YOLO11自定义数据集迁移学习效果对比
查看>>
OpenCV学堂 | YOLOv8官方团队宣布YOLOv11 发布了
查看>>
OpenCV学堂 | YOLOv8实战 | 荧光显微镜细胞图像检测
查看>>
OpenCV学堂 | 汇总 | 深度学习图像去模糊技术与模型
查看>>
OpenCV安装
查看>>
OpenCV官方文档 理解k - means聚类
查看>>
opencv实现多路播放
查看>>
opencv常用函数
查看>>