四.结构体性数组在内存的表现形式

结构体性数组在内存的表现形式

1.上节课我们讲解了单纯的一个结构性变量在内存的排列方式
2.这节课我们来看看如果是结构性数组会是什么排列方式呢
3如下:

#include <stdio.h>
#include "windows.h"
typedef struct  INFO
{
	char flag;
	int id;
	float fd;
}INFO;
INFO info[2] = { {'H',1001,666.66f} ,{'E',8201,-999.88f} };
int main()
{
	printf("%c-%d-%f\n", info[1].flag, info[1].id, info[1].fd);
	printf("Hello Heart");
	system("pause");
	return 0;
}

4.XDBG附加 调到main我们观察下 找到我们数组的首地址 观察汇编 如图:
四.结构体性数组在内存的表现形式

5.下端 观察eax
四.结构体性数组在内存的表现形式

6.好 我们拿到地址后 观察下结构体数组的内存排列形式
7.我们知道结构体大小为0xc大小 也就是12个字节
四.结构体性数组在内存的表现形式

8.观察发现每12个字节为一个结构体 精密的排列在一起
9.我们就明白了 其实结构性数组和我们一些基本类型的数组存放是一样的
10.因为我们之前讲数组的时候说过, 数组是存放相同类型的数据 并且是线性关系
11.虽然我们结构体里面的成员类型不一样 但是我们用结构体包装了一下 就成了一样的数据类型了
12.这时候我们就能存放在数组中了

修改内存对齐后的结构性数组内存变化

1…那么此时我们修改内存对齐 再来看看
四.结构体性数组在内存的表现形式

2你会发现 这样子很难看出数据是什么

总结

1.结构性数组其实就是把每个结构体的成员变量放在数组中
2.结构性数组的步长就是结构体的大小
3.我们可以看到结构体首地址+1 其实加的12字节

迪大交流群:285530835

上一篇:剑指 Offer 12. 矩阵中的路径


下一篇:算法训练 数列