我一直以为:
float* x = new float[100];
这样的初始化申请内存, (x+0)
到 (x+100)
之间这100个位置,所有的数据都是0,然而实际上我错了:
来看下结果值:
看到了吗,不全是0,甚至有 NaN,回到标题,这就是 NaN 出来的原因
所以 C++ 这样初始化数组,一定要手动每个位置给 0
接下来进行项目复盘,这俩天把同事numpy写的函数重写成C++,打印某个变量,大部分都对得上,只有小部分对不上,这是numpy的结果
这是C++的结果:
离谱不,赫然出现了俩 NaN,其他位置都是对的
接下来进行反向debug:
- 我第一反应是内存位置读错了,不过不对啊,读错了应该直接给我返回段错误啊,而且其他位置应该不对啊,怎么能就中间俩是错误的呢
- 那就是给数组对应位置赋值的操作有问题,也不对啊,因为依次赋值是个大循环,要错都错,要对都对,怎么能就中间出错呢?保险起见,我打印了每次赋值操作的值,都是实数没问题
- 第一点表示代码逻辑没问题,第二点表示放数据的操作没问题,接下来就是放数据的容器(就是这个数组)出了问题,果不其然,回到本文开头打印初始数组,果然有问题,有NaN,不全是0
好嘞,问题找到了,解决办法,就是下边那行,一次初始化给0就行
那你可能就有疑问了,我之前怎么没有这个问题呢,我从来不给0初始化呀,那是因为你有了数组之后,是直接做的赋值操作,而本文的操作是:
直接进行的 +=
操作,所以才出现这个问
That’s all.
Original: https://blog.csdn.net/HaoZiHuang/article/details/126748738
Author: 氵文大师
Title: C++数组莫名其妙出现NaN——记一次由C++数组错误初始化导致的问题
原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/760265/
转载文章受原作者版权保护。转载请注明原作者出处!