首先,大端也就是高字节数据放在低地址的内存;小端也就是高字节数据存放在高地址的内存中;
其次,要明确栈空间生长模型与内存生长模型不同。栈空间生长是从高地址向低地址(向下)生长,但是内存生长是向高地址生长的。比如申请一个包含10个元素的char数组a,a[0]…到a[9] 内存地址分别是x,x+1,x+2…x+9。就是内存生长与栈生长方向相反的,新来的变量会根据占用内存的大小在栈空间选择一个起点,然后存放数据。
好了,那么
union{
char a;
int b;
}
这个联合体的内存模型是怎么样?应该是b的起始地址与a的起始地址是相同的,同时联合体占用4B内存,a是在最低地址的那个B中的。
这时候可以判断大小端了
因为0x00000001中,1是低字节。又因为a放在联合体中低地址的一个B,如果读取test.a,他的值为1,说明低字节存放在低地址,是小端模式;如果不为1,说明是大端模式。
目前51单片机和网络字节序都是大端模式的,其他的单片机或电脑一般都是小端。(如有纰漏欢迎指正)