当前位置: 首页 > news >正文

【C++】科普:C++中的浮点数怎么在计算机中表示?

这里我们以8.25这个数为例说明计算机时如何存取float类型的数据的:

float a = 8.25;

引言

1. 所占位数

首先,明确一个概念,float类型的数据在常规计算机中通常占4个字节,也就是32位。其内存分布如图:

在这里插入图片描述

位字段说明所占位数具体含义
符号位1说明浮点数正负,0表示正,1表示负
指数位8说明浮点数的指数,也有正负,大于127为正,小于127的为负
尾数位23浮点数的尾数位

2. 科学计数法

在十进制中,我们了解科学计数法。

例如,825的科学计数法表述为:8.25*102,0.0825的科学计数法表述为:8.25*10(-2)

请注意观察这一点:整数部分的值是大于1小于10的。后面的指数部分也有正指数和负指数。

2. 计算步骤

1. 二进制表示

将8.25用二进制数表示出来:

首先:整数部分为8,二进制表示为1000;

其次,小数部分为0.25,为二进制表示计算方法和整数部分的计算方法恰恰相反,整数部分转换二进制的时候是不断除以2得到的,这里就是不断乘以2:

0.25*2 = 0.5,整数部分为0,记下:0

0.5*2 = 1.0,整数部分为1,记下:1

则0.25的二进制表示即为0.01,即1*2^(-2);

在这一阶段,我们得出结果:8.25的二进制表示为:1000.01

2. 使用科学计数法来表示

在引言里介绍了十进制的科学计数法,同理我们推理出二进制的科学计数法:

8.25的二进制表示为:1000.01;

1000.01的二进制科学计数法表示为:1.00001*2^3

请根据引言中的注意事项,可以推理出:在二进制的科学计数法中:整数部分的取值只能是1,是个固定值。

因此在表示中可以直接把这一步写死,根本不需要去表示整数部分。

3. 转化为计算机存储数据

1.00001*2^3

在引言里,我们已经知道了浮点数在计算机中的表示方法,套用这套表示方法,我们可以知道:

符号位:

8.25是一个正数,因此这位为0.

指数位:

指数位为+3,所以这里的值为127+3=130,130的二进制表示为1000 0010,因此这里为1000 0010。

尾数位:

小数位为00001,这里尾数位占用23个字节,位数不够,所以补0,因此这里为:00001后面补18个0。

4.得出结论

浮点数8.25在计算机中的二进制表示为:0 1000 0010 0000 1000 0000 0000 0000 000

http://www.lryc.cn/news/42847.html

相关文章:

  • Linux 多线程:多线程和多进程的对比
  • IO流你了解多少
  • 【C++】C++ 11 新特性之auto关键字
  • nodejs的后端框架egg,thinkjs,nestjs,nuxtjs,nextjs对比
  • SpringBoot @SpringBootTest 无法启动服务
  • PyTorch深度学习实战 | 神经网络的优化难题
  • 如何缩小pdf文件的大小便于上传?在线压缩pdf工具推荐
  • 使用C++编写一个AVL的增删改查代码并附上代码解释
  • React/ReactNative 状态管理: redux-toolkit 如何使用
  • 14基于双层优化的电动汽车优化调度研究
  • 古茗科技面试:为什么 ElasticSearch 更适合复杂条件搜索?
  • 【数据结构】哈希表
  • 物联网常用协议MQTT协议相关介绍
  • 【C语言进阶】13. 假期测评②
  • 【国产FPGA】国产FPGA搭建图像处理平台
  • 你的应用太慢了,给我司带来了巨额损失,该怎么办
  • 第十四届蓝桥杯三月真题刷题训练——第 22 天
  • 机器学习:朴素贝叶斯模型算法原理(含实战案例)
  • Linux 多线程:理解线程
  • Web前端学习:章四 -- JavaScript初级(四)-- BOM
  • Lesson9.网络基础1
  • 这几个SQL语法的坑,你踩过吗
  • 算法基础——复杂度
  • 基类与派生类对象的关系 派生类的构造函数
  • 【算法】生成分布式 ID 的雪花算法
  • Linux系统编程 - 基础IO(IO操作)
  • 基于 Avue 的 CRUD 表格组件封装
  • 树莓派学习笔记(十三)基于框架编写驱动代码
  • vue事件修饰符之.prevent
  • 【SpringCloud AlibabaSentinel实现熔断与限流】