C++ NAN 异常处理
来源:互联网 发布:c语言http服务器 编辑:程序博客网 时间:2024/05/22 16:58
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 值中的特定位模式来表达某些诊断信息。
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 }
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
- C++ NAN 异常处理
- 'CALayer position contains NaN: [nan nan]'异常
- 关于'CALayer position contains NaN: [nan nan]'异常
- 关于'CALayer position contains NaN: [nan nan]'异常
- python dataframe NaN处理
- c#中的异常处理
- 异常处理 - [C++]
- c异常处理
- Objective-c异常处理
- C语言异常处理
- c 异常处理
- C 异常处理设计
- [C++] 异常处理
- C++“异常处理”
- objective-c 异常处理
- 【C++】栈空栈满异常处理
- C++:异常处理
- c++_10: 异常处理
- 游戏中的路径动画设计与实现
- Host 'XXX' is not allowed to connect to this MySQL server 解决方法/开启MySQL远程账号
- Asp.net 三种事务处理
- Qt Creator:怎么生成一个动态库和调用动态库
- libgdx thinking之慎用static
- C++ NAN 异常处理
- 高内聚低耦合 的理解(转)
- overridePendingTransition的简介
- 类和对象
- buychinaphone.com Strong transport services, global free shipping, global free customs tax
- Eclipse 常见错误解决方案
- 网络技术之——WebView(轻松展示各种网页)
- opencv 函数pointPolygonTest 检测一个点是否在多边形内
- pktgen使用详解