大小端字节序问题

来源:互联网 发布:淘宝怎么样刷信誉 编辑:程序博客网 时间:2024/05/17 08:24
大端模式(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;
}


数据的低字节存储在低地址位置,高字节存储在高地址位置,可知主机的字节序是小端模式。
0 0