如何判断 double/float 变量是否有效 (#IND, #INF)

来源:互联网 发布:淘宝卖家手机打印快递 编辑:程序博客网 时间:2024/05/17 07:16

C/C++程序运行有时候会出现-1.#IND0, +1.#IND0, +1.#INF0, -1.#INF0.
一般来说是除数为0得出的结果,INF就是infinite,就是无穷大的意思;IND可能表示很小,不确定。

使用类似于pow, exp等等函数时常会产生一个无效数字1.#IND00.


其实解决办法很简单,使用   float.h中一个函数_isnan即可:
int _isnan(double x);  //此函数只能判断是否是-1.#IND0, +1.#IND0.

当x是一个无效值(NaN, Not a Number) 时,返回非零值,否则返回0。


float.h中还有应该函数_finite(),可以判断是否是+1.#INF0, -1.#INF0.

int _finite( double x );

_finite returns a nonzero value if its argument x is not infinite; that is, if –INF <x < +INF. It returns 0 if the argument is infinite or a NAN.




原创粉丝点击