C语言当中的nan

传送门:http://www.cnblogs.com/dosrun/p/3908617.html

产生:

对浮点数进行了未定义的操作;

  1. 对负数开方,对负数求对数,0.0/0.0,0.0*inf、inf/inf、inf-inf这些操作都会得到nan。(0/0会产生操作异常;0.0/0.0不会产生操作异常,而是会得到nan);
  2. 在GNU中,使用宏:float NAN对浮点数赋值;

判定:

库函数方法:(推荐)

<见后>

自定义函数:

 int isNumber(double d){return (d==d);}来判断d是否为nan,若d是nan则返回0,否则返回非零值。

注意:

  1. nan是无序的(unordered),它不大于、小于或等于任何数(包括它自己),所以,nan==nan 结果是0或false;另外将<,>,<=,和>=作用于nan产生一个exception;
  2. 得到nan时就查看是否有非法操作;
  3. 如果表达式中含有nan,那么表达式的结果为nan;
  4. 对于NaN的实现有两种方式:signaling NaN 和 quiet NaN。signaling NaN就是抛出异常的方式,因此它不需要定义NaN宏。quiet NaN就是即使在计算出现异常的情况下也不抛出异常从而中断程序的执行、而是将结果表示为一个特殊的值, 因此只有在这种情况下NaN宏才被定义;

C语言当中的inf

infinity (linux),等同于 #INF:infinity (windows)

产生:

超出浮点数的表示范围(溢出,即阶码部分超过其能表示的最大值);

  1. 1.0/0.0等于inf,-1.0/0.0等于-inf,0.0+inf=inf;log(0);
  2. 在C99中,使用宏:float INFINITY对浮点数赋值;

判定:

库函数方法:(推荐)

<见后>

自定义函数:

int isFiniteNumber(double d) {return (d<=DBL_MAX&&d>=-DBL_MAX);}
来判断d是否为一个finite数(既不是inf,又不是nan(加入d为nan,则d参加比较就会得到false(0)值))。

注意:

  1. +inf大于任何数(除了它自己和nan);-inf小于任何数(除了它自己和nan);
  2. 得到inf时就查看是否有溢出或者除以0;
  3. 头文件<float.h>中,有定义的常量DBL_MAX,这个常量表示“能表示出来的最大的双精度浮点型数值”。<float.h>中还有常量DBL_MIN,DBL_MIN表示可以用规格化表示的最小的正浮点数,但DBL_MIN并不是最小的正浮点数,因为可以用可以用非规格化浮点数表示的更小;
  4. inf在C语言表达式中就表示数学里无限的概念,如1.0/inf等于0.0,并可以与其他浮点数进行比较的(可以参与<=、>+、==、!=等运算);

库函数方法判定inf和nan

下面这几个宏(用宏实现的,使用时跟函数的形式基本相同)是判断一个表达式的结果是否为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。(有些较早的编译器版本中,无论是正无穷还是负无穷,都返回非零值,不区分正负无穷)。
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值