记录一个C++操作8位影像的一个bug

目录

Bug描述

接到反馈,说我的程序输出影像有空洞,如图

arcmap上看白色的区域RGB对应的都是0,0,0

我想起代码中难道没有进行判断,对于8位影像,如果像素值为0,就将它置1,避免出现空洞情况。

代码核查

代码截图如下:

代码中本来就有了对8位值像素的判断,为何输出像素值还有0,这是不可能出现的事情。但是现在就是出现了。我以为是其他地方代码有问题,到处排查没有其他相关代码,最核心的地方就在这里。

修改验证

我只做了一个修改,将dstValue用int强转一下,验证代码如下:

cpp 复制代码
dstValue = int(pow(dstValue, LightScale));

经过重新编译,测试验证,输出影像正常了,没有RGB都是0,0,0的问题了,最小都是1,1,1

分析

我修改的动机

为什么这么改,因为我仔细盘算了一下dstValue 是double类型,dstimg数组是unsigned char* 类型 ,所以我感觉是否这个dobule数据转到unsigned char出了问题,为啥会出现0,我怎么也想不到,只是为了验证是否这个问题。最后问题就这样解决了。

豆包分析原因

因为这个问题的确不知道为啥,想让豆包帮我分析。所以描述完问题后,她回到如下:








我的总结

其实豆包分析的很牵强,如果说是小于0,我用逻辑判断就已经置1了,但如果我置1了,为什么最终转换结果还是0。

另外豆包说是小概率事件发生了,为啥客户那边机器出现这个问题,我这边可以完全复现,所以这不是小概率事件,而是必然事件。

我自己的总结很可能是:我发布的是release版本程序,编译器的优化导致的double到unsigned char转换问题。另外用豆包推荐的代码建议也测试了,比较精简,输出影像也正常。

对我的收货:以后在数据类型转换的时候多留个心眼

相关推荐
apocelipes18 小时前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
郝学胜_神的一滴2 天前
CMake 034:生成器表达式:解耦构建时序、精简分支逻辑的终极利器
c++·cmake
见过夏天3 天前
C++ 基础入门完全指南
c++
用户805533698034 天前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
BadBadBad__AK5 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境5 天前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
卷无止境5 天前
OpenMPI、MPICH 与 OpenMP:关系、核心概念与架构全解
c++·后端
郝学胜_神的一滴6 天前
CMake 30:循环语法全解|foreach_while双循环精讲、迭代技巧与实战避坑指南
c++·cmake
卷无止境8 天前
C++ 的Eigen 库全解析
c++
卷无止境8 天前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端