首先字节序是针对一个一个字节来说的,一个字节以内的话是不涉及字节序的问题的。这里可以类比:古汉语的行文顺序是从右到左的,人们就是从右到左来读的;现代汉语的顺序是从左到右的,人们就是从左到右来读的。
大端:高位字节存在低地址,低位字节存在高地址。
小端:高位字节存在高地址,低位字节存在低地址。
人们规定网络字节序都是大端的,主机字节序可以是小端也可以是大端。在网络中跑的都是大端的字节序,在接收端根据本机的情况决定是否转换。
下面的程序可以用来测试大小端程序:
/*
字节序:字节在内存中的存储顺序
小端字节序:数据的高位字节存储在内存的高位地址,低位字节存储在内存的低位地址
大端字节序:数据的低位字节存储在内存的高位地址,高位字节存储在内存的低位地址
*/
//通过代码检测当前主机的字节序
#include <stdio.h>
int main(){
union un
{
short value;// 两个字节
char bytes[sizeof(short)];// char[2]
}test;
test.value = 0x0102;
if(test.bytes[0] == 1 && test.bytes[1] == 2){
printf("Big Endian.\n");
}
else if (test.bytes[0] == 2 && test.bytes[1] == 1){
printf("Little Endian.\n");
}else
{
printf("Unknow.\n");
}
return 0;
}