C语言中浮点型存储方式

2024-04-26 17:28
文章标签 语言 方式 存储 浮点

本文主要是介绍C语言中浮点型存储方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       前言

         这次是上次博客的续写哦,如果有小伙伴不了解,可以点击链接跳转

        C语言中整数与浮点数在内存中的存储

        我们在上次的博客中给大家留了一段代码,不知道大家现在有没有想明白呢,让我来为大家揭秘吧!!

        

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;
}

        运行结果

        

        我们看着这个代码心中是有不少疑惑吧

        代码解析

        首先我们开辟一个名为n的内存空间用来存放数字9,大家注意,这个9是以整型的形式存放进去的,之后我们建立一个浮点型的指针名字叫pFloat,将n的地址交给pFloat,当然在将n的地址交给一个浮点型的指针的时候需要强制类型转化一下。

        当我们以将n以整型的方式拿出时,n的值为9(printf("n的值为:%d\n",n))这句话表示将n以整型的方式拿出。

        但是看看我们下一条代码,当我们将n的值以浮点数的视角取出来的时候,这个时候n的值变成了0.000000,那么在这个过程中发生了什么呢,可以说明什么问题呢?这两条代码可以证明,整数与浮点数在内存中的存储方式是不一样的,这样我们取出它们的数据才会有区别。

        如果大家觉得这样还不够,我们再继续往下看。

        我们以浮点数的形式将9.0放入pFloat,之后我们在整型的视角使用%d取出n中的数值,我们发现,n变成了一个很大的值。但是当我们使用浮点数的形式将n拿出的时候,n还是9.000000。

        整型和浮点型在内存中存储的区别

        那么我们来看看具体在内存中是怎么存储的吧

        int n=9;

        这条代码是将n以整型的形式放入内存中,那么这里放入n的补码

        n的补码:00000000 00000000 00000000 00001001

        我们将n以浮点数的形式拿出

        n的浮点数形式:0 00000000 00000000000000000001001

        我们根据IEEE 754,写出它的标准形式

        n=(-1)^0*0.00000000000000000001001*2^*-126

        这里要注意喽,为什么后面的指数是-126呢,这是我们上一篇讲到的E全为0的特殊情况,当E全为0的时候,浮点数的指数E等于1-127既为真实值,所以我们这里E的指数为-126。

        这个数字的有效数字M的值为0.00000000000000000001001,之后还要乘2^-126,所以结果是一个无限接近与0的数字,我们取小数点后6位那么这里就是0.000000。

        我们再来看看* pFloat = 9.0

        我们将9.0以浮点型的方式存储在内存中

        首先我们来看看9.0的二进制是多少

        1001.0

        1.001*2^3

        (-1)^0*1.001*2^3

        所以这里我们

        S = 0

        M = 1.001

        E = 3    3+127 = 130

        这里我们存储的就是

        0 10000010 00100000000000000000000

        当我们以浮点数的方式取出时,结果就是9.0

        当我们将浮点数存入的数据看作是整型存放的数据时,就会出现代码运行之后的很大的数值

        整型存储

        01000001 00010000 00000000 00000000

        那么这样我们在取出的时候就会发现符号位为0,这个数就是二进制补码,直接读取数值,得到结果,之后我们通过计算机验证,得到的结果果然和程序运行结果相同。

        计算机验证结果

        

        那么到这里大家是不是已经明白,整型和浮点型在内存中存储方式的区别啦,希望可以帮助到大家,加油加油!!

        

        

这篇关于C语言中浮点型存储方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/938200

相关文章

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

Java发送SNMP至交换机获取交换机状态实现方式

《Java发送SNMP至交换机获取交换机状态实现方式》文章介绍使用SNMP4J库(2.7.0)通过RCF1213-MIB协议获取交换机单/多路状态,需开启SNMP支持,重点对比SNMPv1、v2c、v... 目录交换机协议SNMP库获取交换机单路状态获取交换机多路状态总结交换机协议这里使用的交换机协议为常

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

k8s admin用户生成token方式

《k8sadmin用户生成token方式》用户使用Kubernetes1.28创建admin命名空间并部署,通过ClusterRoleBinding为jenkins用户授权集群级权限,生成并获取其t... 目录k8s admin用户生成token创建一个admin的命名空间查看k8s namespace 的

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda