您的位置:首页 > 其它

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

2013-04-27 10:17 337 查看
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.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: