operator + =产生零

时间:2011-06-05 19:04:11

标签: c++ operators

[编辑]问题解决了 - 有点儿。从来没有真正的问题。似乎调试器对我说谎。感谢[/编辑]

到目前为止,我遇到了一个我无法解决的奇怪问题。我有一个私人班级成员

private:
float *_histVals;

在构造函数中初始化如下:

// allocate memory for the histogram bins
size_t hSize = binsPerChan*binsPerChan*binsPerChan;
this->_histVals = new float[ hSize ];
for (size_t i = 0; i < hSize; ++i)
    this->_histVals[i] = 0.0f;

稍后在程序中我想以下列方式向某些数组元素添加内容:

this->_histVals[ hIndex ] += imgFrac;

这里,imgFrac是大小为1.0 * e-5的浮点值,_histVals[ hIndex ]元素的当前值为零。但是,调试器显示在执行此行之后,该值仍为零。

我怀疑浮点精度存在问题,但是当我尝试使用局部浮点变量时,它的效果非常好。所以它必须与数组本身有关。但我不知道那可能是什么。我还检查了数组范围内的索引。

任何可能导致问题的建议? 感谢

1 个答案:

答案 0 :(得分:4)

使用std::vector<float>,除非您想要过上艰难的生活,或者您正在学习人们如何在过去的糟糕日子里生活。

关于这对数组元素没有影响:

this->_histVals[ hIndex ] += imgFrac;

可能的原因:

  • 调试器骗你。
  • imgFrac为零

您是否尝试将所有涉及的值记录到std::cout?同时为了说服自己没有任何魔法,请尝试将其分解为:

float newValue = this->_histVals[ hIndex ] + imgFrac;
this->_histVals[ hIndex ] = newValue;

并记录newValue