【C语言进阶】数据的存储----浮点型篇

🍁 博客主页:江池俊的博客

💫收录专栏:C语言—探索高效编程的基石
💻 其他专栏:数据结构探索
💡代码仓库:江池俊的代码仓库
🎪 社区:GeekHub

🍁 如果觉得博主的文章还不错的话,请点赞👍收藏🌟 三连支持一下博主💞

文章目录

  • 🌟浮点型在内存中的存储
  • 🌟浮点数的存储规则
  • 🌟C语言中如何``存储``浮点数?
    • 📌IEEE 754浮点数表示
    • 📌单精度浮点数(float)
    • 📌双精度浮点数(double)
  • 🌟C语言中如何``读取``浮点数?
  • 🌟练习题
    • 📌1.练习1
    • 📌2.练习2
  • 🌟总结

🌟浮点型在内存中的存储

常见的浮点数:

3.14159
1E10 = 1 × \times × 1010(即10000000000.000000)
浮点数家族包括: float、double、long double 类型。
浮点数表示的范围:float.h中定义
在这里插入图片描述

🌟浮点数的存储规则

在C语言中,浮点型数据(如float和double)在内存中的存储方式通常遵循国际标准IEEE(电气和电子工程协会) 754,这是一种用于表示浮点数的二进制标准。这个标准定义了两种常见的浮点数表示形式:单精度(float)和双精(double)。任意一个二进制浮点数V可以表示成下面的形式:

  • (-1)S × \times × M × \times × 2E
  • (-1)S表示符号位,当S=0,V为正数;当S=1,V为负数。
  • M表示有效数字,大于等于1,小于2。
  • 2E表示指数位。

🌟C语言中如何存储浮点数?

📌IEEE 754浮点数表示

IEEE 754标准将浮点数分为三个部分:符号位、指数部分和有效数字部分。每个部分在内存中占据不同数量的位,具体取决于是单精度还是双精度浮点数。
IEEE 754对有效数字M和指数E,还有一些特别规定。

前面说过, 1≤M<2 ,也就是说,M可以写成 1.xxxxxx 的形式,其中xxxxxx表示小数部分。
IEEE 754规定,在计算机内部保存M时,默认这个数的第一位总是1,因此可以被舍去,只保存后面的xxxxxx部分。
比如:保存1.01的时候,只保存01,等到读取的时候,再把第一位的1加上去。这样做的目的,是节省1位有效数字。
以32位浮点数为例,留给M只有23位,将第一位的1舍去以后,等于可以保存24位有效数字。

至于指数E,情况就比较复杂。 指数E的存储方式

首先,E为一个无符号整数(unsigned int)
这意味着,如果E为8位,它的取值范围为0 ~ 255;如果E为11位,它的取值范围为0~2047。但是,我们知道,科学计数法中的E是可以出现负数的,所以IEEE 754规定,存入内存时E的真实值必须再加上一个中间数,对于8位的E,这个中间数是127;对于11位的E,这个中间数是1023。
比如:210 的E是10,所以保存成32位浮点数时,必须保存10+127=137
即 10001001。

📌单精度浮点数(float)

对于32位的浮点数,最高的1位是符号位s,接着的8位是指数E,剩下的23位为有效数字M
在单精度浮点数中,内存结构如下:

  [S]      [E]       [M]
[符号位] [指数位] [有效数字位]1       8         23
  • 符号位 S(1 bit):表示正负号。

  • 指数位 E(8 bit):表示指数部分 (点击跳转到 - 指数E的存储方式)

  • 有效数字位 M(23 bit):表示小数部分,使用二进制分数表示。

图示:
在这里插入图片描述
比如:
0.5(1/2)的二进制形式为0.1,由于规定正数部分必须为1,即将小数点右移1位,则为1.0 × \times × 2-1其阶码为-1+127=126,表示为01111110,而尾数1.0去掉整数部分为0,补齐0到23位00000000000000000000000,则其二进制表示形式为:

0 01111110 00000000000000000000000

📌双精度浮点数(double)

对于64位的浮点数,最高的1位是符号位S,接着的11位是指数E,剩下的52位为有效数字M。
双精度浮点数的内存结构如下:

  [S]      [E]       [M]
[符号位] [指数位] [有效数字位]1       11        52
  • 符号位 S(1 bit):表示正负号。
  • 指数位 E(11 bit):表示指数部分 (点击跳转到 - 指数E的存储方式)
  • 有效数字位 M(52 bit):表示小数部分。

图示:
在这里插入图片描述

这种内存表示方式使得浮点数可以在计算机上进行精确表示和计算,但也引入了浮点数计算中的一些挑战和限制。

🌟C语言中如何读取浮点数?

指数E从内存中取出可以分成三种情况:

1. E不全为0或不全为1

  • S:直接取出,0表示正数,1表示负数
  • E:指数E的计算值减去127(或1023),得到真实值
  • M:将有效数字M前加上第一位的1。

2. E全为0

  • S:直接取出,0表示正数,1表示负数
  • E:浮点数的指数E等于1-127(或者1-1023)即为真实值
  • M:有效数字M不再加上第一位的1,而是还原为0.xxxxxx的小数。这样做是为了表示±0,以及接近于0的很小的数字。

3. E全为1

  • S:直接取出,0表示正数,1表示负数
  • E:指数E的计算值减去127(或1023),得到真实值
  • M:这时,如果有效数字M全为0,表示±无穷大(正负取决于符号位s)

🌟练习题

📌1.练习1

在这里插入图片描述

📌2.练习2

下面程序输出结果是什么?

int main()
{int n = 9;float *pFloat = (float *)&n;printf("n的值为:%d\n",n);printf("*pFloat的值为:%f\n",*pFloat);*pFloat = 9.0;printf("num的值为:%d\n",n);printf("*pFloat的值为:%f\n",*pFloat);return 0;
}

结果:
在这里插入图片描述
分析:

int main()
{int n = 9;//将 0x00000009 拆分,得到第一位符号位s=0,后面8位的指数 E=00000000 ,//最后23位的有效数字M=000 0000 0000 0000 0000 1001。//9 --> 0 00000000 00000000000000000001001 正数原码=反码=补码//      S    E              M//E全为0,所以真实值为1-127 = -126 //上一节第二种情况:M = 0.00000000000000000001001//S = 0//由于指数E全为0,所以符合上一节的第二种情况。因此,浮点数V就写成://V = (-1)^0 * 0.00000000000000000001001 * 2^(-126) = 1.001 * 2^(-146)//显然,V是一个很小的接近于0的正数,所以用十进制小数表示就是0.000000。float* pFloat = (float*)&n;//n --> int*printf("n的值为:%d\n", n);//9printf("*pFloat的值为:%f\n", *pFloat);// 0.000000....(非常小的数)*pFloat = 9.0;//首先,浮点数9.0等于二进制的1001.0,即1.001×2^3。//(-1)^0 * 1.001 * 2^3//S = 0//E = 3+127 = 130//M = 00100000000000000000000 有效数字M等于001后面再加20个0,凑满23位//0 10000010 00100000000000000000000//S    E              M//这个32位的二进制数,还原成十进制,正是 1,091,567,616 。printf("num的值为:%d\n", n);//--> 1,091,567,616printf("*pFloat的值为:%f\n", *pFloat);//9.0return 0;
}

🌟总结

浮点数在计算机内部的存储方式由IEEE 754标准定义,它将浮点数分为单精度和双精度,每种表示都有符号位、指数部分和有效数字部分。了解浮点数的内存表示有助于我们更好地理解浮点数的行为,预测计算结果,并在编程中避免潜在的精度问题。在进行涉及浮点数的计算时,始终要考虑到浮点数表示可能引起的舍入误差,以获得正确的结果。

🔥今天的分享就到这里,如果觉得博主的文章还不错的话,请👍三连支持一下博主哦🤞
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/23655.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在线课堂,视频点播,springboo+vue

springbootvue三端&#xff08;管理后台&#xff0c;教师端&#xff0c;用户端&#xff09;端可提供源码&#xff0c;可远程安装&#xff0c;需要的加微信&#xff1a; 体验地址&#xff1a;http://edu.dgrxs.com/ 用户端&#xff1a; 管理端&#xff1a; 教师端&#xff1a;

酷开系统 | 酷开科技,让数据变得更有价值!

身处信息时代&#xff0c;我们每个人时刻都在生成、传递和应用数据&#xff0c;数据已经成为了现代社会中宝贵的资源之一&#xff0c;而在人工智能领域&#xff0c;数据更是被称为人工智能的“燃料”。 而在AI的发展中&#xff0c;只有拥有高质量、多样性且充分代表性的数据集…

【javaSE】 万字带你了解String类

目录 String类的重要性常用方法字符串构造使用常量串构造直接newString对象使用字符数组进行构造 String对象的比较比较是否引用同一个对象boolean equals(Object anObject) 方法int compareTo(String s) 方法int compareToIgnoreCase(String str) 方法 字符串查找char charAt(…

【雕爷学编程】MicroPython动手做(31)——物联网之Easy IoT 2

1、物联网的诞生 美国计算机巨头微软(Microsoft)创办人、世界首富比尔盖茨&#xff0c;在1995年出版的《未来之路》一书中&#xff0c;提及“物物互联”。1998年麻省理工学院提出&#xff0c;当时被称作EPC系统的物联网构想。2005年11月&#xff0c;国际电信联盟发布《ITU互联网…

蓝桥杯上岸必刷!!! (进制、数位专题)

蓝桥杯上岸必刷&#xff01;&#xff01;&#xff01;(进制、数位专题) 距离蓝桥杯省赛倒数最后1天 ❗️ ❗️ ❗️ 还没背熟模板的伙伴们背起来 &#x1f4aa; &#x1f4aa; &#x1f4aa; 大家好 我是寸铁&#x1f4aa; 真题千千万万遍&#xff0c;蓝桥省一自然现&#…

ChatGPT今日宣布推出6大新功能,体验效果更佳

今天“一起学英语”群的KV大神发了一张截图&#xff0c;原来OpenAI官方账号发布了一条推文&#xff08;或者称之为X文&#xff1f;&#xff09;&#xff0c;广而告之&#xff1a;下周要上功能了。 这次更新的功能共计6条&#xff0c;看来OpenAI已准备腹泻式更新&#xff0c;即版…

2023年C++面试宝典

目录 第一章&#xff1a;C基础知识1.1 C语言起源与发展1.2 C的重要特点和优点1.3 C的数据类型和变量1.4 函数和命名空间1.5 运算符和表达式 第二章&#xff1a;面向对象编程2.1 类与对象的概念2.2 封装、继承和多态2.3 构造函数和析构函数2.4 静态成员和常量成员2.5 虚函数和纯…

【电源专题】充电IC与DC-DC有什么区别

充电IC和DC-DC一样使用很广泛,如手机、平板等需要电池供电的系统中,一般都会见到充电IC的身影。那么大家有没有考虑过一个问题。充电IC与DC-DC有什么区别? 首先如下所示为充电IC的两个阶段,一个阶段是恒流充电阶段,我们一般称之为CC阶段,另一个是恒压充电阶段,我们称之为…

debug思路 - maven构建报错

问题&#xff1a;maven面板中&#xff0c;进行compile、deploy操作时报错。 debug步骤&#xff1a; 1、鼠标右键选择“修改运行配置”。在运行命令中添加参数-X&#xff0c;用于产生执行调试输出。例如&#xff1a;compile -f -X pom.xml。 2、再次进行compile、deploy操作&…

命令模式-请求发送者与接收者解耦

去小餐馆吃饭的时候&#xff0c;顾客直接跟厨师说想要吃什么菜&#xff0c;然后厨师再开始炒菜。去大点的餐馆吃饭时&#xff0c;我们是跟服务员说想吃什么菜&#xff0c;然后服务员把这信息传到厨房&#xff0c;厨师根据这些订单信息炒菜。为什么大餐馆不省去这个步骤&#xf…

element+vue 之动态form

1.页面部分 <div v-for"(item,index) in formList" :key"index"><el-col :span"6" v-if"item.inputType0"><el-form-item :label"item.conditionName" :prop"item.conditionCode":rules"{req…

Excel·VBA定量装箱、凑数值金额、组合求和问题

如图&#xff1a;对图中A-C列数据&#xff0c;根据C列数量按照一定的取值范围&#xff0c;组成一个分组装箱&#xff0c;要求如下&#xff1a; 1&#xff0c;每箱数量最好凑足50&#xff0c;否则为47-56之间&#xff1b; 2&#xff0c;图中每行数据不得拆分&#xff1b; 3&…

视频汇聚平台EasyCVR视频广场侧边栏支持拖拽

为了提升用户体验以及让平台的操作更加符合用户使用习惯&#xff0c;我们在EasyCVR v3.3版本中&#xff0c;支持面包屑侧边栏的广场视频、分组列表、收藏这三个模块拖拽排序&#xff0c;并且该操作在视频广场、视频调阅、电子地图、录像回放等页面均能支持。 TSINGSEE青犀视频…

Docker 容器化学习

文章目录 前言Docker架构 1、 docker安装2、启动docker服务3、设置docker随机器一起启动4、docker体验5、docker常规命令5.1、容器操作docker [run|start|stop|restart|kill|rm|pause|unpause]docker [ps|inspect|exec|logs|export|import] 5.2、镜像操作docker images|rmi|tag…

前端页面--视觉差效果

代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><link rel"stylesheet" href"https://un…

三层交换实验

前言 在实际的企业应用中&#xff0c;我们会先建立不同的vlan把用户先隔开来。然后再通过三次交换机技术打通vlan直接的网络。 这样的目的如下&#xff1a; 隔离&#xff1a; 隔离是广播域&#xff0c;也就是隔离的是故障连通&#xff1a; 连通的是正常的通信 比如校园网&am…

⛳ StringBuffer and StringBuilder 处理字符串

目录 ⛳ StringBuffer and StringBuilder 处理字符串&#x1f3a8; 一&#xff0c;简介&#x1f3ed; 二&#xff0c;常用方法&#x1f69c; 三 &#xff0c;StringBugger&#x1f43e; 四&#xff0c;StringBuilder⭐ 五&#xff0c;StringBuffer和StringBuilder面试 ⛳ Strin…

2023牛客暑期多校训练营6 A-Tree (kruskal重构树))

文章目录 题目大意题解参考代码 题目大意 ( 0 ≤ a i ≤ 1 ) , ( 1 ≤ c o s t i ≤ 1 0 9 ) (0\leq a_i\leq 1),(1 \leq cost_i\leq 10^9) (0≤ai​≤1),(1≤costi​≤109) 题解 提供一种新的算法&#xff0c;kruskal重构树。 该算法重新构树&#xff0c;按边权排序每一条边…

分布式异步任务处理组件(七)

分布式异步任务处理组件底层网络通信模型的设计--如图&#xff1a; 使用Java原生NIO来实现TCP通信模型普通节点维护一个网络IO线程&#xff0c;负责和主节点的网络数据通信连接--这里的网络数据是指组件通信协议之下的直接面对字节流的数据读写&#xff0c;上层会有另一个线程负…

PoseiSwap:基于 Nautilus Chain ,构建全新价值体系

在 DeFi Summer 后&#xff0c;以太坊自身的弊端不断凸显&#xff0c;而以 Layer2 的方式为其扩容成为了行业很长一段时间的叙事方向之一。虽然以太坊已经顺利的从 PoW 的 1.0 迈向了 PoS 的 2.0 时代&#xff0c;但以太坊创始人 Vitalik Buterin 表示&#xff0c; Layer2 未来…