未初始化的浮点(C++)
Uninitialized float (C++)
如果您想用"未初始化"状态初始化浮点,您会选择什么值?(易于测试且最不可能与实际值混淆的值)
浮动最小值=-9999999。;
可能会出现问题,可能与实际值混淆,甚至由于模糊浮点舍入而被测试(看起来很天真:-)
如果您想避免使用float
的有效值,可以使用NAN:
#include <limits>
....
float min = std::numeric_limits<float>::quiet_NaN();
然后可以使用std::isnan
检查:
#include <cmath>
....
bool not_cool = std::isnan(min);
您可以使用NAN。然而
问题是使用了未初始化的浮点变量。与整数不同,并非所有的位模式都可用作浮点点值。存在一类被称为信号NaNs的值,或简称SNaN,它们是特殊的"非数字"值。如果你问处理器,它将密切关注这些信号NaN和遇到"无效操作数"异常时引发该异常。(这,毕竟,这就是它被称为信号NaN的全部原因。)
此外,我建议您使用Boost。可选,如下所示:
boost::optional<float> minValue; // initially unset
根据变量名min
判断,您希望它尽可能大。这样,与该值的任何比较都将是一个较小的值,并更新您的minValue
。
float minValue = std::numeric_limits<float>::max();
附言:不要将您的变量命名为min
,否则您将面临名称隐藏问题的风险。
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 同时具有"聚合初始化"和"模板推导"
- 初始化具有非默认构造函数的std::数组项的更好方法
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 在C和C++中初始化结构中的数组
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 在函数内部的声明中初始化数组,并在外部使用它
- 继承:构造函数,初始化C++11中基类的类C数组成员