目录
一、数据类型
在剖析数据在内存中的存储之前,我们先来了解一下C语言中的数据类型;
1、内置类型
内置类型是C语言本身就有的类型。根据数据在内存中存储的方式,我们可以将类型分为2类,一类是整型,另一类是浮点型,因为char类型在内存中存储的是其ASCII码值,所以也可以将其划分到整型家族。
2、自定义类型
自定义类型有四种,分别是
数组类型
结构体类型 struct
枚举类型 enum
联合类型 union
我们可以根据需求,用C语言本身自带的类型构造出某一类型,这种类型称为构造类型,又称自定义类型。
3、指针类型
4、空类型
void表示空类型(无类型)
一般用于函数的返回值、参数、指针等;
上图定义了一个函数,无返回类型,无参数。
二、整型在内存中的存储
在了解了C语言中的类型后,我们再来一个一个了解不同的类型在内存中的存储。
1、进制的转换
因为计算机中存储的都是二进制0和1,所以我们有必要了解一下进制的转换;
上图简单的解释了各个进制是如何转化成十进制的。我们之后要常用的有十六进制、十进制和二进制。
2、原码、反码和补码
对于整数,我们再将其分类,分为正的整数和负的整数(将0视为正的整数)。
对于正数来说,其原反补相同,对于负数,适用上图的原则;对于有符号数来说,最高位为0表示正,为1表示负。
接下来我们看一段代码
其中0x是用16进制表示
这时我们将程序调试一下,打开内存窗口,&a &b观察一下a ,b在内存中存储的是什么形式
对比一下,我们可以看到内存中存放的是补码,可是看起来怪怪的,为什么好像是倒着存放的?这个我们马上会解释,先来总结一下:整数在内存中存放的都是其二进制补码。
为什么要存储补码呢,首先我们要知道,CPU只有加法器,只能计算加法,那么我们来计算一下1+(-1)
还有一点,对于原码和补码之间的转化,是除符号位外按位取反+1;不论是原码到补码,还是补码到原码,都适用这个规则;
所以,使用补码,方便计算机计算。
3、大、小端存储
现在我们解决一下刚刚那个问题,为什么感觉数据在内存中是倒着存的。
计算机的内存中以字节为单位存放数据,每一个字节都有一个自己的地址。当我们声明一个整型变量 int a = 0x11223344; 时,系统为变量 a 申请了4个字节的空间,将 a 的内容存放到内存中时,有两种方式:
我们可以把 a 的高位(0x11),存放在 a 的低地址处,如左边;也可以把 a 的低位(0x44)存放到 a 的低地址处,如右边。
大端字节序存储:数据的高位存放在低地址;小端字节序存储:数据的低位存放在低地址。
可以看到,在我当前的计算机中,数据是按小端字节序存储在内存中的。
而对于不同的计算机,所采用的存储方式可能是不同的。
本篇博客于此结束,若想了解浮点数在内存中的存储,可以查看 浮点数在内存中的存储 ,这篇文章有简单易懂的介绍。如果有任何疑问,欢迎在评论区留言。