1, NaN即Not a Num,只对于浮点数出现。
当浮点数的除第一位外的其他位均为1时,该浮点数成为NaN。比如,内存表示为0xFFFFFFFFFFFFFFFF的double型数为NaN。
当两个超出范围的浮点数(即INF)进行运算时,运算结果会成为NaN。
4. The include file
isnan() — Test for NaN
ROOT 中是 Int_t TMath::IsNaN(Double_t x)
==============================================
==============================================
5,Native C++ _isnan()函数的应用
当浮点数的除第一位外的其他位均为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 用于处理计算中出现的错误情况,比如 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 }
isnan() — Test for NaN
ROOT 中是 Int_t TMath::IsNaN(Double_t x)
==============================================
==============================================
5,Native C++ _isnan()函数的应用
当表示一个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."); }