数据存储
深度解析数据在内存中的存储
数据类型的基本归类:
前面我们已经学习了基本的内置类型,现在咱们基本归类一下
- 整型家族:
char
unsigned char (无符号字符类型)
signed char (有符号字符类型)
short
unsigned short [int] (无符号字符类型)
signed short [int] (有符号字符类型)
int
unsigned int
signed int
long
unsigned long [int]
signed long [int]
- 浮点型家族
float
double
- 构造类型(自定义类型)
数组类型
结构体类型struct
枚举类型enum
联合类型union
- 指针类型
int *p;
char *p;
float *p;
void *p;
- 空类型(无类型) void
- 通常应用于函数的返回类型、函数的参数、指针类型
整形在内存中的存储
一个变量的创建是要在内存中开辟空间的。
空间的大小是根据不同的类型而决定的
例如:
int a = 10;
- 我们都知道 a 是占四个字节的空间
那如何存储 ? 下面来了解一下
原码、反码、补码
计算机中的整数有三种2进制表示方法,即原码、反码和补码。
三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”而数值位
正数的原、反、补码都相同。
负整数的三种表示方法各不相同
原码
直接将数值按照正负数的形式翻译成二进制就可以得到原码。反码
将原码的符号位不变,其他位依次按位取反就可以得到反码。补码
反码+1就得到补码。
整数在内存中存储的形式都是用补码
之前的操作符的详解中详细的讲过正数和负数在二进制的表示,下面有链接
链接: 操作符详解
大端字节序和小端字节序介绍
我们可以看到下面图片中 a 和 b 分别存储的是补码,是以十六进制显示的
但是我们发现顺序有点不对劲,为什么呢
- 这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8 bit。由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。
- 因此就导致了大端存储模式和小端存储模式
大端字节序
大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址
中;
小端字节序
小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地
址中。
练习题:
写一个程序来判断当前编译器的字节序
- 思路:
- 代码实现
int main()
{
int a = 1;
char* b = (char*)&a;
if (*b == 1)
printf("小端\n");
else