他们力量的源泉,是值得信赖的搭档以及想要保护的对象还有强大的敌人

本文收录于青花雾气-计算机基础

往期回顾

从汇编代码探究函数栈帧的创建和销毁的底层原理

从0到1搞定在线OJ

数据在内存中的存储

计算机存储的大小端模式

目录

浮点数的二进制转化及存储规则等

浮点数计算规则

1.指数向高位对齐

2.运算过程中的进位问题


大家好,我是纪宁。

这篇博客将给大家介绍浮点数在内存中是如何进行计算的

浮点数的二进制转化及存储规则等

在上次介绍了数据在内存中是如何存储的,其中就介绍了浮点数是如何在内存中存储的

不懂浮点数的二进制是如何转化和存储的可以去看我的这篇博客

数据在内存中的存储

其中详细介绍了浮点数的二进制如何转化以及国际标准IEEE规定的浮点数在内存中的存储方法

以下为简单复习

一个浮点数可以统一写成   (-1)^S * M * 2^E,其中(-1)^S表示这个浮点数的正负,当S=0时,表示这个浮点数为正值;S=1表示这个浮点数为负值。M表示有效数字,大于等于1,小于2,上例中有效数字M就是1.01101。2^E表示指数位,上例中E=2。如图所示

以5.625举例子,5.625的二进制位形式是101.101

这是浮点数在内存中的存储形式

E+127/255存入,M去掉1存入

说了这么多,但是浮点数在内存中到底是如何计算的呢?

其实浮点数计算和存储的时候还是略有差别

浮点数计算规则

1.指数向高位对齐

什么意思呢?

如果两个浮点数进行相加,一个的E=3,一个的E=2,那么就要将E=2的浮点数转化为E=3的浮点数

转化方法就是改变这个浮点数的有效数字,将有效数字再次前移

例如5.625要与9.125相加

5,625的E=2,有效数字为1.01101

9.125的E=3,有效数字为1.001001

5.625的E小于9.125的E,所以将5.625的E改为3,同时将它的有效数字前移1位

从1.01101变成0.101101

所以在计算的时候,5.625的V就变了,如图

将改变之后的M部分按二进制位运算方法运算,这个结果就是最终结果的有效数字

再将这个数字乘指数部分即可以得到最终结果

2.运算过程中的进位问题

上例解释了5.625和9.125的相加,但他们有效数字的小数点后第一位的数字加起来没有超过1,那么该如何计算呢?计算完又将如何存储?

例如进行5.625+9.75的浮点数运算

9.75----->1001.11----->1.00111      E=3

可以看出,当出现进位的情况,在计算的时候正常计算即可,只需要存储的时候有所差别

因为计算M结果的时候并不是在存储位置本身的地方进行的,是先取出来计算,然后计算完将结果重新储存进去,所以不用担心会有溢出的情况

内存有足够的空间去存储

那么浮点数在内存中的运算到这里就结束了,因为计算机CPU中只有加法

至于浮点数的乘法、减法、除法等,都可以转化为浮点数的‘加法’

如一个浮点数减一个浮点数

可以转化为一个浮点数加另一个浮点数的负数,其他都是类似的原理

浮点数在内存中的运算相关推荐

  1. IEEE754标准: 浮点数在内存中的存储方式

    一. 什么是IEEE754标准 我们知道, 计算机内部实际上只能存储或识别二进制. 在计算机中, 我们日常所使用的文档, 图片, 数字等, 在储存时, 实际上都要以二进制的形式存放在内存或硬盘中, 内 ...

  2. 【C语言进阶】③探究浮点数在内存中的存储方式

    文章目录 一.例题 二.浮点数在内存中存储方式 2.1国际标准IEEE(电气和电子工程协会)754规定: 2.2实际上,浮点数在内存的存储形式为: 2.3具体M和E是怎么算的呢? 三.题解 3.1刚开 ...

  3. 详谈单精度浮点数在内存中的存储及其误差问题

    本文主要对单精度浮点数的范围大小进行一些简单的讨论. 分为五部分: 一.单精度浮点数的取值范围 二.单精度浮点数在内存中的存储形式 三.单精度浮点数的范围及其实现原理的关系 四.单精度浮点数在计算中造 ...

  4. 浮点数在内存中的表示

    2011年4月9日10:09:19 c语言中的浮点数在内存中的表示(VC++编译器中): char:1个字节 short:2个字节 int:4字节 long:4字节 float:4字节(单精度) do ...

  5. C/C++浮点数在内存中的存储方式《转》

    那天有人在汇编群里有人问了一个 #include <iostream> #include <stdio.h> using namespace std; int main() { ...

  6. 原码,反码,补码,加法减法在计算机内存中的运算方法

    什么是原码:所有数转化成二进制的序列就是原码[正数原反补相同] 什么是补码:原码通过取反得反码,反码+1得补码[负数存的是补码] 所有信息在计算机在内存中,都是由二进制方式存储 计算机自能进行加法运算 ...

  7. 浮点数在内存中的存储

    我们已经介绍过整数在内存中的存储方式,那浮点数在内存中是怎样存储的呢? 先看一段代码: #include<stdio.h>int main() {int n = 9;float* pFlo ...

  8. 浮点数在内存中的存储——“C”

    各位CSDN的uu们你们好呀,今天,小雅兰的内容是浮点数在内存中的存储,昨天我们已经写过了整型在内存中的存储,那么,浮点数在内存中是怎样存储的呢?现在,就让我们进入浮点数在内存中的存储的世界吧 常见的 ...

  9. 详解浮点数在内存中的存储

    目录 前言 一. 32 位单精度浮点数在内存中的存储 1.1 - 符号位 sign 1.2 - 偏移后的指数位 biased exponent 1.3 - 尾数位 fraction(mantissa) ...

最新文章

  1. 分布式配置管理--百度disconf搭建过程和详细使用
  2. cuda 历史版本下载
  3. Android Listview 点击item变黄色
  4. 经典算法刷题笔记pdf
  5. 机器学习模型 知乎_机器学习-模型选择与评价
  6. 《机器学习实战》笔记(01):机器学习基础
  7. [转]SharePoint对象模型性能考量
  8. mysql赋予权限的时候报错_想要远程连接MySQL,赋予root权限没用啊?一直报语法错误...
  9. 面试问到springmvc不会怎么办?看这篇就够了,springmvc面试题(共22题,含答案)
  10. camera(24)---camera 客观测试 Imatest教程--噪声测试
  11. android开发之路05
  12. 实验三 密码破解技术 201521410010
  13. 内网通过公网地址访问内部服务器
  14. 大白话聊聊Java并发面试问题之Java 8如何优化CAS性能?
  15. 中国最好的论坛(未分类版)
  16. 200道Java灵魂考题:全部掌握拿下阿里P7腾讯T3.2
  17. 巨准SCRM私域案例拆解丨看看WonderLab如何霸屏朋友圈
  18. 《Kotlin极简教程》第1章 Kotlin简介
  19. 部署策略对比:蓝绿部署、金丝雀发布及其他
  20. (小说)代码,也是有温度的。一个35岁程序员的心理蜕变。

热门文章

  1. 阴阳师角色系统转移开通的服务器,阴阳师角色转移攻略,登录平台怎么转换?只需这样做...
  2. 基于matlab的升压斩波实验,基于MATLAB的升压斩波电路的仿真_贾立柱
  3. MS Office开发工具
  4. 行走的offer收割机,这份十万字Java面试总结已经帮助上百人拿到大厂offer,还不快冲?
  5. 计算机网络幅移键控法,1.4.2 理解键控法
  6. 国内比较好的网站建设公司有哪些?
  7. WebLogic RMI 反序列化漏洞
  8. 项目实训-智能生物序列分析平台-药物推荐后端日志
  9. 调速器方案(智能数字显示),可做6W~250W的单相电机数显智能调速器
  10. 【资讯】TypeScript 官网新主页上线!