对于多字节数据类型(例如short、int),Big endian 第一个字节是最高位字节(按照从低地址到高地址的顺序存放数据的高位字节到低位字节)。而Little endian 则相反,第一个字节是最低位字节(按照从低地址到高地址的顺序存放数据的低位字节到高位字节)。
今天才知道原来位段也遵守这个规则,怪不得在看IP数据包头(版本号、首部长度)时感觉怪怪的。
struct iphdr {
#if defined(__LITTLE_ENDIAN_BITFIELD)
__u8 ihl:4,
version:4;
#elif defined (__BIG_ENDIAN_BITFIELD)
__u8 version:4,
ihl:4;
#else
#error "Please fix <asm/byteorder.h>"
#endif
__u8 tos;
__u16 tot_len;
__u16 id;
__u16 frag_off;
__u8 ttl;
__u8 protocol;
__u16 check;
__u32 saddr;
__u32 daddr;
/*The options start here. */
}
C语言中的位域结构也要遵循端模式。
例如:
struct edtest
{
uchar a : 2;
uchar b : 6;
}
该位域结构占1个字节,假设赋值 a = 0x01; b=0x02;
大端机器上该字节为: (01)(000010)
小端机器上: (000010)(01)
因此在编写可移植代码时,需要加条件编译。