C语言详细图解浮点型数据的存储实现

 更新时间:2022年05月06日 15:07:35   作者:利刃Cc  
使用编程语言进行编程时,需要用到各种变量来存储各种信息。变量保留的是它所存储的值的内存位置。这意味着,当您创建一个变量时,就会在内存中保留一些空间。您可能需要存储各种数据类型的信息,操作系统会根据变量的数据类型,来分配内存和决定在保留内存中存储什么

在引入知识之前,先来看一个案例,就知道了解浮点型数据存储的重要性与必要性。

举个例子:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int num = 9;
	float *pnum = (float *)&num;//强制转换类型
	printf("n的值为:%d\n",n);
	printf("*pFloat的值为:%f\n",*pnum);
	*pnum = 9.0;
	printf("num的值为:%d\n",n);
	printf("*pFloat的值为:%f\n",*pnum);
	return 0;
}

一般情况下我们都会认为*pnum打印的就是n的值,只不过是以浮点型打印出来,所以是9.000000啊,然后下面的n又因为*pnum的修改,加之因为%d输出,所以还是9啊,但是结果不是,打印出来的结果如下图所示:

结果与我们想的有很大的偏差。。。。。那就有必要让我们来了解浮点型数据的存储啦!

1.首先,根据上面的实例,我们可以发现整型和浮点型数据的存储方法是不一样的!

2.那么浮点型数据是怎么存储的呢?

(1)根据国际标准IEEE(电子和电子工程协会)754,任意一个二进制浮点数V可以表示为下面的形式:

## (-1)^S * M * 2^E

## (-1)^S 表示符号位,当S=0时,V为正数;当S=1时,V为负数。

## M 表示有效数字,且1<=M<2

## 2^E表示指数位

举例来说:十进制的 5.0,写成二进制是 101.0,相当于 1.01 *2^2 。那么,按照上面的V的格式,可以得出S=0,M=1.01,E=2。

十进制的 -5.0,写成二进制是 -101.0 ,相当于 -1.01 * 2^2 。那么,S=1,M=1.01,E=2。

IEEE 754规定对于任意一个浮点数V都可以表示成V=(-1)^s * M *2^E,那我们是不是只要知道S、M、E三个值就可以确定一个浮点数?事实上,c语言内存存储浮点数时,也确实是只存储S、和指数E有关的一个值、和M有关的一个值(注意,这里不是直接存E、M) 详情如下:

相对应的float型是32位的,它的存储空间如下:

相对应的double型是64位的,它的存储空间如下:

对于M与E的特别规定:

E的使用:

所以我们再对刚才的代码加以解释:

1.首先我们先把n的补码写出来,因为n是正数,所以它的原反补相同。

2.按照上面的方法,把n的补码分解后发现它的E为全0,所以相当于一个无穷小的数字,所以此时*p为0.000000……

3.将*p改成9.0后按照上面的方法,先改成二进制 1001.1,然后写成 (-1)^0 * 1.001 * 2^3,最后按照格式变成补码,存到内存中去,此时补码为01000001000100000000000000000000,而n为整型数据,所以先取出这个补码,又因为其为正数,所以直接将补码转为十进制%d输出:

结果与我们之前执行的结果一致!

浮点型数据存储是很重要的知识点,它也加强了我们对数据存储的了解!

到此这篇关于C语言详细图解浮点型数据的存储实现的文章就介绍到这了,更多相关C语言数据存储内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解C++中mutable的用法

    详解C++中mutable的用法

    这篇文章主要介绍了详解C++中mutable的用法,帮助大家更好的理解和学习C++,感兴趣的朋友可以了解下
    2020-08-08
  • c语言经典习题之逆序字符串详解

    c语言经典习题之逆序字符串详解

    这篇文章主要为大家介绍了c语言习题之逆序字符串,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • 基于C语言实现关机小游戏的示例代码

    基于C语言实现关机小游戏的示例代码

    关机会写吧!猜数字会写吧!本文将结合这两个功能,用C语言编写一个关机恶搞小游戏(最好的朋友转瞬即逝),只要猜对了,1分钟后执行关机,除非输入“我是猪”,但是输完后,1分钟后还是会执行关机,该保存保存,感兴趣的可以尝试一下
    2022-07-07
  • ubuntu 下编译C++代码出现的问题解决

    ubuntu 下编译C++代码出现的问题解决

    这篇文章主要介绍了ubuntu 下编译C++代码出现的问题解决的相关资料,需要的朋友可以参考下
    2015-03-03
  • 在C语言中比较两个字符串是否相等的方法

    在C语言中比较两个字符串是否相等的方法

    这篇文章主要介绍了在C语言中比较两个字符串是否相等的方法,分别介绍了strcmp()函数和strcasecmp()函数,注意功能区分,需要的朋友可以参考下
    2015-08-08
  • C++中的Qt QTableView详解

    C++中的Qt QTableView详解

    这篇文章主要介绍了Qt QTableView详解,主要包括常用接口,设置item属性,右键弹出菜单,结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • C语言for循环嵌套for循环在实践题目中应用详解

    C语言for循环嵌套for循环在实践题目中应用详解

    初学C语言,常常遇到for循环中嵌套个for循环,初学者对于这种形式总是一知半解,这次我就整理了常见的for循环嵌套for循环的题目,我们一起争取一举拿下这类题。学废他们,以后再见到就不怕啦!每天都要学一点呀。加油,奋斗的我们
    2022-05-05
  • Qt图形图像开发之Qt曲线图美化QChart QScatterSeries 空心点阵图,鼠标移动到上面显示数值,鼠标移开数值消失效果实例

    Qt图形图像开发之Qt曲线图美化QChart QScatterSeries 空心点阵图,鼠标移动到上面显示数值,鼠标移开

    这篇文章主要介绍了Qt图形图像开发之Qt曲线图美化QChart QScatterSeries 空心点阵图,鼠标移动到上面显示数值,鼠标移开数值消失效果实例,需要的朋友可以参考下
    2020-03-03
  • C语言实现将字符和数字串到一起

    C语言实现将字符和数字串到一起

    今天小编就为大家分享一篇C语言实现将字符和数字串到一起,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12
  • C语言顺序查找算法介绍及示例

    C语言顺序查找算法介绍及示例

    顺序查找又称线性查找,主要用于在线性表中进行查找。顺序查找通常分为对一般的无序线性表的顺序查找和对按关键字有序的顺序表的顺序查找,下面我们来一探究竟
    2022-08-08

最新评论