C++ NaN

非原创!

原文地址:

http://blog.163.com/chen_dawn/blog/static/112506320125494852135/

1, NaN即Not a Num,只对于浮点数出现。
当浮点数的除第一位外的其他位均为1时,该浮点数成为NaN。比如,内存表示为0xFFFFFFFFFFFFFFFF的double型数为NaN。
当两个超出范围的浮点数(即INF)进行运算时,运算结果会成为NaN。

2,NaN错误

NaN,是Not a Number的缩写。   
NaN 用于处理计算中出现的错误情况,比如 0.0 除以 0.0 或者求负数的平方根。由上面的表中可以看出,对于单精度浮点数,NaN 表示为指数为 emax + 1 = 128(指数域全为 1),且尾数域不等于零的浮点数。IEEE 标准没有要求具体的尾数域,所以 NaN 实际上不是一个,而是一族。不同的实现可以自由选择尾 数域的值来表达 NaN,比如 Java 中的常量 Float.NaN 的浮点数可能表达为01111111110000000000000000000000,其中尾数域的第一位为 1,其余均为 0(不计隐藏的一位),但这取决系统的硬件架构。Java 中甚至允许程序员自己构造具有特定位模式的 NaN 值(通过 Float.intBitsToFloat() 方法)。比如,程序员可以利用这种定制的 NaN 值中的特定位模式来表达某些诊断信息。

NAN是指not a number。

浮点数在进行除零操作之后,就会变成NAN(INF)。

可以使用下列函数来判断该值是否为NAN(INF)。

库函数:int isnan(double);  

    int _finite(double);//vc下使用该函数

//若传入的double值无效,函数返回0. 需要包含库文件<float.h>

也可写自定义函数来进行判断(vc下不行)

1 bool is_nan(double dVal)
2 {
3   if (dVal==dVal)
4     return false;
5
6   return true;
7 }

4. The include file
isnan() — Test for NaN
ROOT 中是 Int_t TMath::IsNaN(Double_t x)


==============================================
==============================================
5,Native C++ _isnan()函数的应用 

 

什么是 Native C++?

当表示一个double型数值不为数字时,在.net可以这样表示

double d = double.NaN;

double.NaN的原型如下:

//
// Summary:
// Represents a value that is not a number (NaN). This field is constant.
public const double NaN = 0.0 / 0.0;

在Native C++,如果想表示一个不为数字的double,可以使用下面的函数。

double GenerateNaN()
{
unsigned long nan[2]={0xffffffff, 0x7fffffff}; // code representing a NaN
return *( double* )nan;
}

判断double类型是不是NaN,可以使用  _isnan() 函数:

double d = GenerateNaN();
if(_isnan(d))
{
printf("d is NaN.");
}
原文地址:https://www.cnblogs.com/anHIZ/p/2890597.html