大端模式(Big endian)
数据的高字节存储在内存低地址中,而数据的低字节则存放在内存高地址中。与思维习惯不一致,但与实际数据的表达方式一致。如PowerPC的UNIX系统
小端模式(Little endian)
数据的高字节存储在内存高地址中,而数据的低字节则存放在内存低地址中。与思维习惯一致,如x86架构的Intel系列产品(常见)
网络字节序
网络字节序标准规定为大端字节序,不同平台上会对主机字节序进行转化,成为网络字节序后再发送传送。
主机字节序的测试
union(联合体/共用体)有个特点:所有的数据成员共有一个空间,同一时间只能存储其中一个数据成员,所有的数据成员具有相同的起始地址。我们定义一个union来测试主机字节序:
typedef union{
unsigned short int value;
unsigned char byte[2];
}typeorder;
value成员是短整型变量,通过byte成员来访问value变量的高低字节便可知主机的字节序。
#include <stdio.h>
typedef union{
unsigned short int value;
unsigned char byte[2];
}typeorder;
int main(int argc, char *argv[])
{
typeorder type;
type.value = 0xabcd;
printf("value=0x%x\n",type.value);
if(type.byte[0] == 0xcd && type.byte[1] == 0xab)
{
printf("Low endian byte order.\n");
printf("byte[0]=0x%x byte[1]=0x%x\n",type.byte[0],type.byte[1]);
}
if(type.byte[0] == 0xab && type.byte[1] == 0xcd)
{
printf("Big endian byte order.\n");
printf("byte[0]=0x%x byte[1]=0x%x\n",type.byte[0],type.byte[1]);
}
return 0;
}
数据的低字节存储在低地址位置,高字节存储在高地址位置,可知主机的字节序是小端模式。