C++ 浮点数(double、float)如何定义NaN、正无穷、负无穷,以及如何判断是否是NaN

浮点数的标准可以看百度百科:http://baike.baidu.com/view/1698149.htm

 

NaN :阶码的每个二进制位全为1  并且  尾数不为0;

无穷:阶码的每个二进制位全为1  并且  尾数为0;符号位为0,是正无穷,符号位为1是负无穷。

 

所以NaN、正无穷、负无穷可以如此定义,可以如此判断是否NaN:

//float
int __NaN=0xFFC00000,__Infinity=0x7F800000,__Neg_Infinity=0xFF800000;
const float NaN=*((float *)&__NaN),Infinity=*((float *)&__Infinity),Neg_Infinity=*((float *)&__Neg_Infinity); 

bool IsNaN(float dat)
{
 int & ref=*(int *)&dat;
 return (ref&0x7F800000) == 0x7F800000 && (ref&0x7FFFFF)!=0;
}

 

//double
__int64 __NaN=0xFFF8000000000000,__Infinity=0x7FF0000000000000,__Neg_Infinity=0xFFF0000000000000;
const double NaN=*((double *)&__NaN),Infinity=*((double *)&__Infinity),Neg_Infinity=*((double *)&__Neg_Infinity); 

bool IsNaN(double dat)
{
 __int64 & ref=*(__int64 *)&dat;
 return (ref&0x7FF0000000000000) == 0x7FF0000000000000 && (ref&0xfffffffffffff)!=0;
}

<think>好的,我现在需要回答用户关于如何在C++中表示负无穷大的问题。首先,我得回忆一下C++中处理无穷大的方法。记得在C++中,可以使用标准库中的数值极限来获取各种数据类型的极值,比如std::numeric_limits。 接下来,用户问的是负无穷大,所以应该针对不同的浮点数类型,比如floatdouble和long double。这时候需要确认如何用std::numeric_limits来获取这些值。例如,std::numeric_limits<double>::infinity()可以得到正无穷,而负无穷则是在前面加上负号,比如-std::numeric_limits<double>::infinity()。 然后,需要考虑整数类型是否支持无穷大。不过根据C++标准,整数类型是没有无穷大表示的,所以这部分需要明确指出,避免用户误解。此外,可能还需要提到在比较操作中的注意事项,比如任何数与负无穷大比较时的情况。 还要注意不同编译器的实现可能有所不同,但大多数现代编译器应该支持这些特性。另外,可能需要提醒用户包含<limits>头文件,否则会编译错误。同时,举例说明具体的代码写法会更有帮助,比如声明一个变量并赋予负无穷的值,然后进行一些比较操作。 最后,总结一下步骤,确保回答结构清晰,覆盖不同数据类型的情况,并指出整数类型的限制。这样用户就能全面了解如何在C++中正确表示和使用负无穷大了。</think>在 C++ 中表示负无穷大可以通过以下方法实现: 1. **浮点数类型的负无穷**(推荐方式) ```cpp #include <limits> double neg_inf = -std::numeric_limits<double>::infinity(); float neg_inf_f = -std::numeric_limits<float>::infinity(); long double neg_inf_ld = -std::numeric_limits<long double>::infinity(); ``` 2. **宏定义方式**(需包含 `<cmath>`) ```cpp #include <cmath> double neg_inf = -INFINITY; // C99/C++11 起支持 ``` 3. **十六进制直接表示**(仅限 IEEE 754 标准) ```cpp double neg_inf = -std::numeric_limits<double>::infinity(); // 等价于: double neg_inf_hex = -0x1.fffffffffffffp+1023; // 不推荐直接使用 ``` **重要说明**: 1. 所有整数类型(int, long 等)没有无穷大表示 2. 使用时需要包含头文件:`<limits>` 或 `<cmath>` 3. 比较特性: ```cpp // 任何有限数都大于负无穷 bool test = (neg_inf < 0); // true bool test2 = (neg_inf < -1e99); // true ``` **验证无穷大的方法**: ```cpp #include <iostream> #include <limits> int main() { double ninf = -std::numeric_limits<double>::infinity(); std::cout << "Is negative infinity: " << std::isinf(ninf) && (ninf < 0) << std::endl; std::cout << "Value: " << ninf << std::endl; // 输出 "-inf" } ``` **注意事项**: - 不同编译器可能有不同实现,但主流编译器(GCC/Clang/MSVC)都支持 - 涉及无穷大的运算需要特别处理,例如: ```cpp ninf + 5 == ninf // true ninf * 0 == NaN // true(产生非数值) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值