判断一个浮点数是否为NAN(INF)

NAN(wiki  en   中文)是指not a number。

INF(wiki en   中文)Infinity(无穷)。

浮点数变成NAN:

① 有一个及以上参数为NaN时    如:1.0f/NaN、1.0f*NaN、NaN+1.0f、NaN-1.0f、Nan^1.0f等

② 下列运算的情况
    除法:0/0、∞/∞、∞/(−∞)、(−∞)/∞、(−∞)/(−∞)
    乘法:0*∞、0*−∞
    加法:∞ + (−∞)、(−∞) + ∞
    减法:∞ - ∞、(−∞) - (−∞)
    指数:0^0、∞^0、1^∞、∞^(−∞)

浮点数变成+INF(极大值)  如:1.0f/0

浮点数变成-INF(极小值)  如:-1.0f/0

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

C库函数(需要#include <float.h>)

int _isnan(double);  // 是否为nan   当为NAN时,返回1;其他情况返回0

int _finite(double);  // 是否为有限数   当为NAN、+INF、-INF时,返回0;其他情况返回1

float f1 = 1.0;
float f2 = -1.0;
float f3 = 0.0;

float f4 = f1/f3;//1.#INF000
float f5 = f2/f3;//-1.#INF000
float f6 = f3/f3;//-1.#IND000
float f7 = -f3/f3;//-1.#IND000

float f8 = f4/f4;//-1.#IND000
float f9 = f5/f5;//-1.#IND000
float fa = -f4/f4;//-1.#IND000
float fb = f1/f6;//-1.#IND000
float fc = f2/f6;//-1.#IND000
float fd = f6/f1;//-1.#IND000
float fe = f6/f2;//-1.#IND000
float ff = f7/f7;//-1.#IND000

float fg = f4/f3;//1.#INF000
float fi = f5/f3;//-1.#INF000

int n0 = _isnan(f1);//0
int n1 = _finite(f1);//1
int n2 = _isnan(f2);//0
int n3 = _finite(f2);//1
int n4 = _isnan(f3);//0
int n5 = _finite(f3);//1
int n6 = _isnan(f4);//0
int n7 = _finite(f4);//0
int n8 = _isnan(f5);//0
int n9 = _finite(f5);//0
int na = _isnan(f6);//1
int nb = _finite(f6);//0

bool b1 = (f1==f1);//true
bool b2 = (f2==f2);//true
bool b3 = (f3==f3);//true
bool b4 = (f4==f4);//true
bool b5 = (f5==f5);//true
bool b6 = (f6==f6);//vc6下b6为true,vs2008下b6为false

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值