结构体性数组在内存的表现形式
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