随笔二十二:C 语言中的浮点数

        C 语言标准不要求使用 IEEE 浮点,所以没有标准的方法来改变舍入方式或者得到诸如-0、+无穷、-无穷或者 NaN 之类的特殊值。大多数系统提供include('.h')文件和读取这些特征的过程库,但是细节因为西哦同的不同而不同。例如,当程序文件中出现下列句子时,GNU 编译器 GCC 会定义程序常数 INFINITY (表示+无穷)和NaN (表示 NaN)。

#define _GNU_SOURCE 1
#include <math.h>

        当在int、float 和 double 格式之间进行强制类型转换时,程序改变数值和位模式的原则如下(假设 int 是 32 位的):

        1)从 int 转换成 float,数字不会溢出,但是可能被舍入。

        2)从 int 或 float 转换成 double,因为 double 有更大的范围(也就是可表示值的范围),也有更高的精度(也就是有效位数),所以能够保留精确的数值。

        3)从 double 转换成 float,因为范围要小一些,所以值可能溢出成为+无穷 或 -无穷。另外,由于精确度较小,它还可能被舍入。

        4)从 float 或着 double 转换成 int,值将会向零舍入。进一步来讲,值可能会溢出。C 语言标准没有对这种情况指定固定的结果。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值