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

来源:互联网 发布:北京排名优化公司 编辑:程序博客网 时间:2024/06/05 11:27

        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 语言标准没有对这种情况指定固定的结果。

原创粉丝点击