我要投搞

标签云

收藏小站

爱尚经典语录、名言、句子、散文、日志、唯美图片

当前位置:财神爷心水论坛 > 非零值 >

C语言中INF和NAN是什么意思

归档日期:06-06       文本归类:非零值      文章编辑:爱尚语录

  可选中1个或多个下面的关键词,搜索相关资料。也可直接点“搜索资料”搜索整个问题。

  注意:1、inf一般是因为得到的数值,超出浮点数的表示范围(溢出,即阶码部分超过其能表示的最大值);而nan一般是因为对浮点数进行了未定义的操作,如对-1开方。

  结果是0或false,即不能和nan进行比较,和nan进行比较得到的结果总是false或0。所以可以用函数: int

  5、得到inf时就查看是否有溢出或者除以0,得到nan时就查看是否有非法操作。

  6、C语言的头文件float.h中,有定义的常量DBL_MAX,这个常量表示“能表示出来的最大的双精度浮点型数值”。float.h中还有常量DBL_MIN,DBL_MIN表示可以用规格化表示的最小的正浮点数,但DBL_MIN并不是最小的正浮点数,因为可以用可以用非规格化浮点数表示的更小。可以用函数:int

  8、inf是可以与其他浮点数进行比较的,即可以参与=、+、==、!=等运算。

  下面这几个宏(用宏实现的,使用时跟函数的形式基本相同)是判断一个表达式的结果是否为inf、nan或其他:

  用来查看浮点数x的情况,fpclassify可以用任何浮点数表达式作为参数,fpclassify的返回值有以下几种情况。

  FP_SUBNORMAL: x太小,以至于不能用浮点数的规格化形式表示。

  FP_NORMAL: x是一个正常的浮点数(不是以上结果中的任何一种)。

  isinf(x) 当x是正无穷是返回1,当x是负无穷时返回-1。(有些较早的编译器版本中,无论是正无穷还是负无穷,都返回非零值,不区分正负无穷)。

  下面这几个宏(用宏实现的,使用时跟函数的形式基本相同)是判断一个表达式的结果是否为inf、nan或其他:

  用来查看浮点数x的情况,fpclassify可以用任何浮点数表达式作为参数,fpclassify的返回值有以下几种情况。

  FP_SUBNORMAL: x太小,以至于不能用浮点数的规格化形式表示。

  FP_NORMAL: x是一个正常的浮点数(不是以上结果中的任何一种)。

  当x是正无穷是返回1,当x是负无穷时返回-1。(有些较早的编译器版本中,无论是正无穷还是负无穷,都返回非零值,不区分正负无穷)。

本文链接:http://chondriac.com/feilingzhi/438.html