如何在linux c下判断nan

如何在linux c下判断nan,第1张

用法

要使用isnan() 宏,请使用缺省的-Ae 选项,或者-Aa 和-D_HPUX_SOURCE 选项进行编译。并确保程序包含

<math.h>。通过指定编译程序命令行或链接程序命令行上的-lm 选项,链接到数学库。

返回

当且仅当其参数具有NaN 值时, isnan() 宏才返回非零值。此宏不引发任何浮点运算异常。

因为NaN和任何数做数学运算结果都是NaN。所以遇到这种情况,你要检查程序每一步的中间结果,看在什么地方第一次出现NaN(例如A处)。改掉这个地方。如果结果还有NaN,那么再对A处之后的程序重复上述过程。B开头$ bc 显示计算器,输入bc后,会出现计算器的版本,此时说明计算器已经被调用。这个计算器是一个简单的计算器。可以实现一些加减乘除的运算。要想显示数据的精度:则要设置scale的值,scale=3,代表有三位小数点。输入quit退出C开头$ cal 显示日历,cal 10 2009 显示2009年10月的日历[ctrl]+c 终止命令 [ctrl]+d 相当于quit/exit$ chgrp 改变档案所属的群组chgrp 要改成的组名 文件 (必须在root下 *** 作)$ chown 改变档案拥有者chown 要改成的用户名 文件 (必须在root下 *** 作)$ chmod 改变档案的权限例如:$ chmod u=x/u=7(相当于u=rwx),g=rwx(相当于g=7)文件名$ chmod 777 文件名 (a代表u、g、o)$ chmod a=rwx(相当于u=7、g=7、o=7) 文件名 (不能写a=7)

inf :infinity (linux) 等同于 #INF:infinity (windows)nan :not a number 等同于 #IND:indeterminate (windows)注意:1、inf一般是因为得到的数值,超出浮点数的表示范围(溢出,即阶码部分超过其能表示的最大值);而nan一般是因为对浮点数进行了未定义的 *** 作,如对-1开方。2、nan==nan 结果是0或false,即不能和nan进行比较,和nan进行比较得到的结果总是false或0。所以可以用函数: int isNumber(double d){return (d==d)}来判断d是否为nan,若d是nan则返回0,否则返回非零值。3、1.0/0.0等于inf,-1.0/0.0等于-inf,0.0+inf=inf;4、对负数开方sqrt(-1.0)、对负数求对数(log(-1.0))、0.0/0.0、0.0*inf、inf/inf、inf-inf这些 *** 作都会得到nan。(0/0会产生 *** 作异常;0.0/0.0不会产生 *** 作异常,而是会得到nan)5、得到inf时就查看是否有溢出或者除以0,得到nan时就查看是否有非法 *** 作。6、C语言的头文件<float.h>中,有定义的常量DBL_MAX,这个常量表示“能表示出来的最大的双精度浮点型数值”。<float.h>中还有常量DBL_MIN,DBL_MIN表示可以用规格化表示的最小的正浮点数,但DBL_MIN并不是最小的正浮点数,因为可以用可以用非规格化浮点数表示的更小。可以用函数:int isFiniteNumber(double d){return (d<=DBL_MAX&&d>=-DBL_MAX)}来判断d是否为一个finite数(既不是inf,又不是nan(加入d为nan,则d参加比较就会得到false(0)值))。7、1.0/inf等于0.0。8、inf是可以与其他浮点数进行比较的,即可以参与<=、>+、==、!=等运算。 下面这几个宏(用宏实现的,使用时跟函数的形式基本相同)是判断一个表达式的结果是否为inf、nan或其他:头文件:include<math.h>宏的用法(类似于函数原型):int fpclassify(x)int isfinite(x)int isnormal(x)int isnan(x)int isinf(x)具体用法:1、int fpclassify(x) 用来查看浮点数x的情况,fpclassify可以用任何浮点数表达式作为参数,fpclassify的返回值有以下几种情况。FP_NAN:x是一个“not a number”。FP_INFINITE: x是正、负无穷。FP_ZERO: x是0。FP_SUBNORMAL: x太小,以至于不能用浮点数的规格化形式表示。FP_NORMAL: x是一个正常的浮点数(不是以上结果中的任何一种)。2、int isfinite(x) 当(fpclassify(x)!=FP_NAN&&fpclassify(x)!=FP_INFINITE)时,此宏得到一个非零值。3、int isnormal(x) 当(fpclassify(x)==FP_NORMAL)时,此宏得到一个非零值。4、int isnan(x) 当(fpclassify(x)==FP_NAN)时,此宏返回一个非零值。5、int isinf(x) 当x是正无穷是返回1,当x是负无穷时返回-1。(有些较早的编译器版本中,无论是正无穷还是负无穷,都返回非零值,不区分正负无穷)。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/yw/7291160.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-03
下一篇 2023-04-03

发表评论

登录后才能评论

评论列表(0条)

保存