位段的字节序

对于多字节数据类型(例如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)
因此在编写可移植代码时,需要加条件编译。

你可能感兴趣的:(位段的字节序)