数据类型——浮点数
1、意义
面对金融和数学程序经常使用浮点数。
2、浮点类型
float、double、long double
3、表示方法
数学中有一般记数法、科学记数法、指数记数法(e记数法)
指数记数法是计算机中的写法。
(有效位数代表了精度,指数代表了可表示数的范围)
C99标准添加了一种新的浮点型常量格式——用十六进制表示浮点型常量。即在十六进制数前加上十六进制前缀(0x或0X),用p和P分别代替e和E,用2的幂代替10的幂(即,p计数法)。如0xa.1fp10,即(10+1/16+15/256)*1024 =10364.0
4、物理层表示方式
4.1、float类型
32位
(符号位)(指数部分)(非指数部分/尾数/有效位)
1+(1+7)+23
至少6位有效数字(2^23=8388608)
3.4E-38,3.4E+38
4.2、double类型(双精度)
64位
(符号位)(指数部分)(非指数部分/尾数/有效位)
1+(1+10)+52
至少13位有效数字(2^52=4503599627370496)
1.7E-308,1.7E+308
4.3、long double类型
(可能)表示更大的浮点数,C只保证long double类型至少与double类型的精度相同
1+(1+14)+112
1.1E-4932,1.1E+4932
5、代码层表示方式
常用指数记数法。
类型 | 存储大小(字节) | 值范围 | 精度 |
---|---|---|---|
float | 4 | 3.4E-38,3.4E+38 | 6位 |
double | 8 | 1.7E-308,1.7E+308 | 15位 |
long double | 16 | 1.1E-4932,1.1E+4932 | 19位 |
6、浮点值的上溢和下溢
6.1、上溢
含义:计算导致数字过大,超过当前类型能表达的范围。
处理:C会给结果赋一个表示无穷大的特定值,而且printf()显示该值为inf或infinity或者具有无穷含义的其他内容。
6.2、下溢
含义:计算导致数字过小,超过当前类型能表达的范围。
处理:可以得到结果,但是损失了原末尾有效位上的数字。(损失了类型全精度的浮点值称为低于正常的浮点值)
6.3、特殊的浮点值NaN
含义:not a number的缩写。输入了超过定义范围的值导致的结果无意义。
处理:函数将返回NaN值,printf()函数可将其显示为nan、NaN或其他类似的内容。
7、浮点数的转换
7.1、浮点数转成二进制
例如:-20.3转为二进制
整数部分20 ->10100
小数部分0.3
0.3*2 = 0.6 (0)
0.6*2 = 1.2 (1)
0.2*2 = 0.4 (0)
0.4*2 = 0.8 (0)
0.8*2 = 1.6 (1)
。。。
所以为10100.010011…1001循环
左移4位为1.010 0110 0110 0110 0110 0110(因为首位必为1,可以省略)
所以尾数为010 0110 0110 0110 0110 0110
最终指数位:2^(8-1)-1 + 4 =131 ->1000 0011
最终二进制为1 1000 0011 010 0110 0110 0110 0110 0110
7.2、二进制转为浮点数
1 1000 0011 010 0001 0000 0000 0000 0000
首位1,负数
指数位1000 0011 = 131,131-127 = 4,左移了4位。
尾数位010 0001 0000 0000 0000 0000
则1.010 0001 0000 0000 0000 0000
右移4位
10100.001 0000 0000 0000 0000
转换:
10100 -> 20
0 * 2^(-1) + 0 * 2^(-2) + 1 * 2^(-3) = 0.125
所以浮点数为20.125
7.3、浮点数转为十六进制
先转换为二进制,再转为十六进制