
1 前言
我们在学习 C 语言时,通常认为浮点数和小数是等价的,并没有严格区分它们的概念,这也并没有影响到我们的学习,原因就是浮点数和小数是绑定在一起的,只有小数才使用浮点格式来存储。
其实,整数和小数可以都使用定点格式来存储,也可以都使用浮点格式来存储,但实际情况却是,C 语言使用定点格式存储整数,使用浮点格式存储小数,这是在 “数值范围” 和 “数值精度” 两项重要指标之间追求平衡的结果。
2 什么是浮点数?
浮点型简单讲就是实数的意思。浮点数在计算机中用以近似表示任意某个实数。具体的说,这个实数由一个整数或定点数(即尾数)乘以某个基数(计算机中通常是 2)的整数次幂得到,这种表示方法类似于基数为 10 的科学记数法。
3 浮点数在内存中的存储
首先明确一点,无论是整型、浮点型还是字符等等数据类型在计算机底层都是以二进制的方式存储的。
浮点数在内存中的存储和整数不同,因为整数都可以转换为一一对应的二进制数据。而浮点数的存储是由符号位 (sign) + 指数位 (exponent) + 小数位 (fraction) 组成。
| 类型 | 符号位 | 指数 | 尾数 |
|---|
浮点数的存储原理与计算
本文介绍了浮点数的概念及其在计算机内存中的存储方式,包括符号位、指数位和小数位。通过实例解析了浮点数19.625在float类型中的存储形式,探讨了float和double的范围与精度,并解释了为何在存储指数时使用偏移量,以解决正负零的问题,最大化利用有限的二进制位来表示更多数值。
订阅专栏 解锁全文
433

被折叠的 条评论
为什么被折叠?



