编程中遇到inf的情况,如何判断C++浮点数无效值

使用时需包含头文件 #include
using namespace std;
include 《limits》

利用C++中的numeric_limits来实现,在C++的头文件#include 中,有各个类型的最值。

如int 对应的最大最小值:std::numeric_limits::min() std::numeric_limits::max()
如float对应的最大最小值:std::numeric_limits::min() std::numeric_limits::max()
如double对应的最大最小值:std::numeric_limits::min() std::numeric_limits::max()

注:numeric_limits::min() 表示的是double的正数最小值,即2.22507e-308,并没有考虑负数。事实上,应该使用numeric_limits::lowest()来取double的负数最小值,即-1.7976931348623157e+308。

例:

if((dValue < std::numeric_limits::lowest()) ||

(dValue > (std::numeric_limits::max)()))

{ // 判断-inf或inf无效数据,需要添加头文件#include

printf("the value is inf or -inf\n");

}

使用VS2010编写的C++程序 std:min 转换到 VS2013无法识别,显示“错误:应输入标识符”。
标准库在头中定义了两个模板函数std::min() 和 std::max()。通常用它可以计算某个值对应的最小值和最大值。可惜在 Visual C++ 无法使用它们,因为没有定义这些函数模板。原因是名字min和max与<windows.h>中传统的min/max宏定义有冲突。解决方法:

1:为了解决这个问题,Visual C++ 定义了另外两个功能相同的模板:_cpp_min() 和 _cpp_max()。我们可以用它们来代替std::min() 和 std::max()。

2:可以禁用Visual C++中的 min/max宏定义,可以在包含<windows.h>头文件之前加上:
#define NOMINMAX
或者将 NOMINMAX 加到 preprocessor difinitions 中。具体方法是:
项目属性—配置属性—C/C+±–预处理器中添加“NOMINMAX”,如下图所示

  1. 在std::max外加上括号,阻止宏替换,即(std::max)()。
    三种方法任选其一即可,2、3亲测可用,第一种还没有尝试过。

https://blog.csdn.net/duiwangxiaomi/article/details/103271222

posted @ 2022-11-24 14:11  mkmkbj  阅读(725)  评论(0编辑  收藏  举报