以前有视频介绍过struct结构体成员排列顺序的不同,因为对齐的原因会造成整个结构体的变量在内存中占用空间的大小也不一样。这次通过Keil软件来实际查看内存的方式来看一下结构体因为成员变量的排序不同到底在内存中浪费的空间会有多大。
这是示例代码,定义了两个结构体,一个结构体是这样排序的,char型的、double型的还有一个char的数组。另外一个成员完全一样,只是把数组排在最前面,char排在数组后面,double型排在最后面。
这样两个结构体的定义定义出来的变量到底会有多大?进行了简单的初始化,然后就把它的占用的空间以及在内存中的地址打印出来。把代码运行一下,在这边设了一个断点,让它直接运行到断点。

·第一个结构体占用的空间是32个字节,地址分配在2000000这个位置。
·第二个结构体占用了24个字节,分布在20000020这个位置。
再打开一个memory监测框,输入地址0X2000000。
来看一下两个结构体到底是怎样对成员进行分配的。
·先看第一个结构体,先是一个char型的变量,初始化的地址,初始化的内容。这一个字符1的ASCII码值是0X31,后面有一个double型的变量,分配的是1.0。
·再后面是一个char型的字符数组,是0到9。
·这个一后面补了很多0,应该是8个0。
根据之前学过的占用空间的计算方式,这里面最大的是double,都根据double来对齐,double在内存中占用8个字节,所以0000开始,1、2、3、4、5、6、7、8,这8个字节都是被char占用了,后面7个字节都是为了对齐来补充的0。这8个字节是为double分配的,这个无可厚非,不管这个变量这个值是多大多小,它都要占用8个字节,这是double本身决定的。
·然后后面还有10个字节的char型的数组,12345678900-9,然后再补充,注意因为是8的倍数来对齐,28=16,所以后面6个字节是注意用括号括起来的,这个部分都是为了对齐编译器自动补充上去的。
·这个结构体它的大小是32个字节,再看下一个,下一个前面是数组是0-9,0123456789在这,然后后面是跟了一个char型的变量,这后面就是因为是double型占8个,所以后面5个字节都是补充的,为了对齐用的。
·然后这个double变量它肯定又占了8个,12345678,这个占用多少个字节?38=24个字节,所以大家看一下这个成员都是一模一样的,只是它的位置发生了变化,然后在内存中就能节约不少空间。
大家看一看,一个结构体的一个变量就能节约8个字节,如果这是一个结构体数组对不对?