数据类型——浮点数

数据类型——浮点数

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、代码层表示方式

常用指数记数法。

类型存储大小(字节)值范围精度
float43.4E-38,3.4E+386位
double81.7E-308,1.7E+30815位
long double161.1E-4932,1.1E+493219位

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、浮点数转为十六进制

先转换为二进制,再转为十六进制

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值