0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

什么是浮点数?浮点数在内存中的存储

冬至子 来源:C语言与CPP编程 作者:LeeWay 2022-11-09 11:07 次阅读

1 前言

我们在学习 C 语言时,通常认为浮点数和小数是等价的,并没有严格区分它们的概念,这也并没有影响到我们的学习,原因就是浮点数和小数是绑定在一起的,只有小数才使用浮点格式来存储。

其实,整数和小数可以都使用定点格式来存储,也可以都使用浮点格式来存储,但实际情况却是,C 语言使用定点格式存储整数,使用浮点格式存储小数,这是在 “数值范围” 和 “数值精度” 两项重要指标之间追求平衡的结果。

2 什么是浮点数?

浮点型简单讲就是实数的意思。浮点数在计算机中用以近似表示任意某个实数。具体的说,这个实数由一个整数或定点数(即尾数)乘以某个基数(计算机中通常是 2)的整数次幂得到,这种表示方法类似于基数为 10 的科学记数法。

3 浮点数在内存中的存储

首先明确一点,无论是整型、浮点型还是字符等等数据类型在计算机底层都是以二进制的方式存储的。

浮点数在内存中的存储和整数不同,因为整数都可以转换为一一对应的二进制数据。而浮点数的存储是由符号位 (sign) + 指数位 (exponent) + 小数位 (fraction) 组成。

1.jpg

int 和 float 同样占据四个字节的内存,但是 float 所能表示的最大值比 int 大得多,其根本原因是浮点数在内存中是以指数的方式存储

浮点数转换到内存中存储的步骤分为如下三步:

  • 将浮点数转换成二进制
  • 用科学计数法表示二进制浮点数
  • 计算指数偏移后的值

对于第3点:计算指数时需要加上偏移量(后面有介绍为什么使用偏移量),而偏移量的值与浮点数的类型有关( float 偏移量值为 127 ,double 偏移量值为 1023)。比方对于指数 6,float 与 double 类型偏移后的值分别为:

  • float : 127 + 6 = 133
  • double:1023 + 6 = 1029

4 实例

浮点数19.625用float是如何存储的:

  • 将浮点数转换成二进制:10011.101(将 19.625 整数部分采用除 2 取余,小数部分采用乘 2 取整法);
  • 用科学计数法表示二进制浮点数:1.0011101*2^4
  • 计算指数偏移后的值:127 + 4 = 131 (10000011);
  • 拼接综上所述,float 类型的 19.625 在内存中的值为:0 - 10000011 - 001 1101 0000 0000 0000 0000。

5 float与double范围和精度

范围

floatdouble的范围是由指数的位数来决定的。(因为表示的时候都是1.x * 2^Y的形式,所以忽略了1.x的效果,直接取指数表示浮点数的范围)

  • float:

1bit(符号位) 8bits(指数位) 23bits(尾数位)

  • double:

1bit(符号位) 11bits(指数位) 52bits(尾数位)

于是,float的指数范围为-127~+128,而double的指数范围为-1023~+1024,并且指数位是按补码的形式来划分的。

其中负指数决定了浮点数所能表达的绝对值最小的非零数;而正指数决定了浮点数所能表达的绝对值最大的数,也即决定了浮点数的取值范围。

float的范围为-2^128 ~ +2^128,也即-3.40E+38 ~ +3.40E+38

double的范围为-2^1024 ~ +2^1024,也即-1.79E+308 ~ +1.79E+308

精度

floatdouble的精度是由尾数的位数来决定的,尾数越多能表示的小数点后面有效数字就越多,因此精度就越高。浮点数在内存中是按科学计数法来存储的,其整数部分始终是一个隐含着的“1”,由于它是不变的,故不能对精度造成影响。

float:2^23 = 8388608,一共七位,这意味着最多能有 7 位有效数字,但绝对能保证的为 6 位,也即float的精度为 6~7 位有效数字;

double:2^52 = 4503599627370496,一共 16 位,同理,double的精度为 15~16 位。

6 解剖:为什么要用偏移量的方式来计算指数?

如果不采用偏移量的方式:

8 位 2 进制数表示的有符号数范围有两个区间:0000 0000~0111 11111000 0000~1111 1111,分别为0~+127-127~0

大家看到这里的问题了吧,有两个 0 ,一个正 0 和一个负 0。

如果采用偏移量的方式:

127 转化为二进制是:0111 1111

那么

  • 当我们要表示 -127,则有127-1270111 1111 - 0111 1111 = 0000 0000
  • 当我们要表示 -126,则有127-1260111 1111 - 0111 1110 = 0000 0001
  • 当我们要表示 -2,则有127-20111 1111 - 0000 0010 = 0111 1101
  • 当我们要表示 -1,则有127-10111 1111 - 0000 0001 = 0111 1110
  • 当我们要表示 0,则有0+1270000 0000 + 0111 1111 = 0111 1111
  • 当我们要表示 1,则有1+1270000 0001 + 0111 1111 = 1000 0000
  • 当我们要表示 2,则有1+1270000 0010 + 0111 1111 = 1000 0001

当我们要表示128,则有128+127即1000 0000 + 0111 1111 = 1111 1111

由上面的例子,我们可以得出规律,采用移位存储技术,我们可以使用 8 位二进制来表示从-127~+128共计 127 个负数+零(0)+ 128 个正数总共 256 个数,看来使用移位存储既没有 +0 和 -0 的问题,又能充分使用新生成的8位二进制数最大限度的表示单精度浮点数的幂指数,是非常合理的。

审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 浮点数
    +关注

    关注

    0

    文章

    60

    浏览量

    15868
收藏 人收藏

    评论

    相关推荐

    小数在内存是如何存储的?为什么C语言中的浮点数不支持位移操作?

    小数在内存是如何存储的?为什么C语言中的浮点数不支持位移操作?
    发表于 08-16 09:24 1048次阅读
    小数<b class='flag-5'>在内存</b><b class='flag-5'>中</b>是如何<b class='flag-5'>存储</b>的?为什么C语言中的<b class='flag-5'>浮点数</b>不支持位移操作?

    浮点数如何存储

    浮点数如何存储玩转浮点数
    发表于 12-30 07:10

    浮点数的表示方法

    浮点数的表示方法  浮点数,是指小数点在数据的位置可以左右移动的数据。它通常被表示成:    N = M* RE  这里的M(Mantissa)被称为浮点数
    发表于 10-13 17:13 1.6w次阅读
    <b class='flag-5'>浮点数</b>的表示方法

    浮点数常用的编码方法

    浮点数常用的编码方法  前面已经说到,在计算机内,浮点数被表示为如下格式:    通常情况
    发表于 10-13 17:21 4483次阅读
    <b class='flag-5'>浮点数</b>常用的编码方法

    modbus 如何读取浮点数

    本文为大家介绍modbus读取浮点数的两个程序设计。
    发表于 02-08 10:03 1.5w次阅读

    单片机浮点数运算的源码设计

    单片机执行程序的过程,实际上就是执行我们所编制程序的过程。即逐条指令的过程。本文详细介绍了浮点数在单片机的表示方式和汇编子程序,浮点数比定点数加减法要困难,但是克服了定
    的头像 发表于 03-07 15:19 1w次阅读
    单片机<b class='flag-5'>浮点数</b>运算的源码设计

    Xilinx怎么定点数浮点数

    转化为的浮点数可以是单精度也可以是双精度。
    发表于 07-05 08:09 3875次阅读
    Xilinx怎么定<b class='flag-5'>点数</b>转<b class='flag-5'>浮点数</b>

    浮点数在内存存储

    浮点数在内存存储和整数不同,因为整数都可以转换为一一对应的二进制数据。而浮点数存储是由符号
    的头像 发表于 09-20 10:52 4053次阅读
    <b class='flag-5'>浮点数</b><b class='flag-5'>在内存</b><b class='flag-5'>中</b>的<b class='flag-5'>存储</b>

    谈一谈浮点数的精度问题

    还是要从浮点数存储和标识出发来处理该问题,既然浮点数天然就存在一定的误差,而有时候计算又无法获得唯一的数值,如下图所示,浮点数计算出来的实轴上的值都会因为
    的头像 发表于 08-11 14:28 4584次阅读
    谈一谈<b class='flag-5'>浮点数</b>的精度问题

    什么是浮点数

    Python数据类型第一种:字符串(str)。 Python数据类型第二种:整数(int)。 Python数据类型第三种:浮点数浮点数的英文名是float,浮点数没有简写。
    的头像 发表于 02-23 14:58 4602次阅读

    PLC浮点数的二进制表示

    我们日常使用的各类数据,都是以二进制的方式存储的。以浮点数为例,在PLC其表示方式使用了IEEE 754标准。许多编程语言中浮点数的实现也遵循该标准。
    的头像 发表于 03-23 13:50 5279次阅读
    PLC<b class='flag-5'>中</b><b class='flag-5'>浮点数</b>的二进制表示

    西门子PLC浮点数程序案例分享

    64位浮点数保存于VB0开始的存储,转换得出的32位浮点数保存于VD100
    发表于 10-27 17:07 3281次阅读
    西门子PLC<b class='flag-5'>浮点数</b>程序案例分享

    单精度和双精度浮点数的区别

    在计算机科学和数值计算浮点数是一种用于表示实数的数据类型。浮点数有两种精度级别:单精度和双精度。这两种精度级别在表示范围、精度和存储空间等方面都有所不同。本文将详细介绍单精度和双精
    的头像 发表于 12-13 10:55 1.1w次阅读

    单精度和双精度浮点数的区别

    单精度和双精度是计算机中表示浮点数的两种不同的精度。在计算机浮点数用来表示带有小数部分的实数,而单精度和双精度用来表示浮点数的精确程度不同。在以下文章
    的头像 发表于 12-15 10:25 5422次阅读

    modbus浮点数怎么读取

    Modbus是一种通信协议,常用于工业自动化系统的设备之间的通信。它支持多种数据类型,包括整数、浮点数、字符串等。浮点数在工业领域中广泛应用,因此了解如何读取和处理Modbus浮点数
    的头像 发表于 12-28 14:38 6200次阅读