简介
“endian”一词来源于乔纳森·斯威夫特的小说格列佛游记。小说中,小人国为水煮蛋该从大的一端(Big-End)剥开还是小的一端(Little-End)剥开而争论,争论的双方分别被称为“大端派”和“小端派”。
字节序,又称端序,尾序(Endianness)。在计算机科学邻域,是跨越多字节的程序对象的存储规则。
在几乎所有的机器上,多字节对象都被存储为连续的字节序列。例如,在C语言中,一个类型为int
的变量x
地址为0x100
,那么,x的四个字节将被存储在存储器的0x100,0x101, 0x102, 0x103
位置。而存储地址内的排列则有两个通用规则。一个多位的整数将按照其存储地址的最低或最高字节排列。如果最低有效位在最高有效位的前面,则称小端序;反之则称大端序。
下面以内存中0x0A0B0C0D的存放方式为例,分别有以下几种方式:
大端序(big-endian)
数据以8bit为单位:
小端序(little-endian)
数据以8bit为单位:
大端小端转换方法
Big-Endian转换成Little-Endian:
#define BigtoLittle16(A) ((((uint16)(A) & 0xff00) >> 8) | (((uint16)(A) & 0x00ff) << 8))
#define BigtoLittle32(A) ((((uint32)(A) & 0xff000000) >> 24) | (((uint32)(A) & 0x00ff0000) >> 8) | \
(((uint32)(A) & 0x0000ff00) << 8) | (((uint32)(A) & 0x000000ff) << 24))
大端小端检测方法
int i = 1;
char *p = (char *)&i;
if(*p == 1)
printf("Little Endian");
else
printf("Big Endian");