C++ NAN 异常处理

来源:互联网 发布:c语言http服务器 编辑:程序博客网 时间:2024/05/22 16:58
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 值中的特定位模式来表达某些诊断信息。

3, vc6下判断一个浮点数是否为NAN(INF)

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.");}
0 0
原创粉丝点击