#include<stdio.h> int a=0x12345678; int main(){ char *p; p=(char*)&a; if(*p==0x78) printf("The little endian\n"); else printf("The big endian\n"); return 0; }
#include<stdio.h> int main(){ int a=0x12345678; char *p; p=(char*)&a; if(*p==0x78) printf("The little endian\n"); else printf("The big endian\n"); return 0; }
处理器是小端网络,这两个程序的运行结果都是 The little endian
对于第一个程序好理解,存在数据段,存放数据是由低地址向高地址的,所以由地址低到高存储的依次为:78 56 34 12,首地址指向78
对于第二个程序,这个a是存在栈区啊,栈区不是由高地址向低地址吗?为什么首地址还是指向78?
栈区增长方向是按照编译器的不同而不同的话,那数据是怎么存储的呢?求指导答
解决方案
10
在C语言中,多字节变量(例如int)存在字节序的问题,即:高位字节存在内存高地址处还是低地址处,为此有大端序和小端序的区别。
题主这里混淆了一个概念,就是字节序跟变量是保存在全局数据区还是在栈区是没有关系的。
其实字节序总结一下很好记忆的
大端序:高低低高
小端序:高高低低
一般x86平台都是小端序,也就是高高低低,即:高位字节存放在内存高地址处,低位字节存放在低地址处。对于整型变量a=0x12345678,其内存布局为78 56 34 12
大端序一般在以太网通信中,所以又叫网络字节序,因此上面的变量a在大端序系统上就是12 34 56 78
此外,栈的生长方向在x86平台都是从高地址往低地址方向,在其他平台则不一定,例如,在ARM平台上,栈的增长方向是可以配置的
题主这里混淆了一个概念,就是字节序跟变量是保存在全局数据区还是在栈区是没有关系的。
其实字节序总结一下很好记忆的
大端序:高低低高
小端序:高高低低
一般x86平台都是小端序,也就是高高低低,即:高位字节存放在内存高地址处,低位字节存放在低地址处。对于整型变量a=0x12345678,其内存布局为78 56 34 12
大端序一般在以太网通信中,所以又叫网络字节序,因此上面的变量a在大端序系统上就是12 34 56 78
此外,栈的生长方向在x86平台都是从高地址往低地址方向,在其他平台则不一定,例如,在ARM平台上,栈的增长方向是可以配置的
20
栈的方向是你后压栈的变量与先压入栈的变量的方向有关,而与单个变量的大端与小端存储无关