数据在内存中的存储相关内容

数据在内存中的存储相关内容

我们已经知道,c语言中有以下这么几种变量类型,分别为:>

char //字符类型
short //短整型
int //整型
long //长整型
long long //更长的整型
float //单精度浮点数
double //双精度浮点数

本文将介绍整型数据在内存中的存储。

首先就是将整型类型归一下类啦,要注意的是,char 类型也归结到整型类型里面,因为字符类型在内存中是以ascii码值进行存储的.

也即整型家族里面一共有这几位成员:>
在这里插入图片描述

我们知道,在创建一个变量的时候,会相应的在内存中开辟一块空间,那么这个变量的数据是如何存储在内存当中的?,我们需要先了解以下几个内容:>

一.原码反码补码

1.原码:

按照该数据直接写出的二进制位就是该数的补码,举个栗子:

我们通过-1直接写出来该二进制序列即为该数的原码,要注意的是,该二进制序列最高位为符号为,负数为1,正数为0

2.反码:

反码在原码的基础上,符号位不变,其他位按位取反,还是上面的例子,我们看一下-1的反码:>

**[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rHAuNVSj-1637644746297)(C:\Users\MSI-NB\AppData\Roaming\Typora\typora-user-images\image-20211122232506362.png)]**

3.补码:

补码在原码的基础上+1即可:
在这里插入图片描述

这就是我们那个熟悉的全1二进制序列了

因此,原反补的计算规则为:

在这里插入图片描述

补码想转化到原码也即以上的逆过程,即补码-1得到反码,然后反码符号位不变,其他位按位取反即可.

上述讨论是基于该数据是负数的情况下,实际上,若数据为正数,其原码反码补码都是一样的,举个栗子

在这里插入图片描述

原码反码补码都为该二进制序列。

而内存中存储的都为补码。可以用原码计算一下-1+1,你会发现结果等于-2,常识告诉我们这是不可能的:

在这里插入图片描述

二.大小端存储

我们先来看一下一个变量在内存中的存储情况:

在这里插入图片描述

我们发现,这个变量在内存中是倒着存储的,即44332211以此存储,实际上,变量在内存中的存储有两种情况:
在这里插入图片描述

我们知道,44是a的低位字节序,如果低位字节序存放在高地址处,高位字节序放在低地址处,则称为大端存储。

而以下

在这里插入图片描述

则称其为小端存储,即将低位字节序的内容存放在低地址处,高位字节序的内容存放在高地址处。

现在我们给出大端小端的概念:

大端存储:指将数据的低位字节序的内容存放在高地址处,高位字节序的内容存放在低地址处。

小端存储:指将数据的低位字节序的内容存放在低地址处,高位字节序的内容存放在高地址处。

现在我们设计一个程序来判断vs环境下是大端存储还是小端存储,我们只需要看一个数据第一个字节中的内容即可,即

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

因此,我们只需要访问到第一个字节的内容即可,那我们就需要用到一个char类型的指针变量。

我们设计出以下程序:>

在这里插入图片描述

结果是:>
在这里插入图片描述

因此,vs编译器底下整型数据存储为小端存储。

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值