位域在结构体中的比特序

    xiaoxiao2025-02-25  56

    一、位域在结构体中的比特序   转自:https://blog.csdn.net/Season_hangzhou/article/details/20364401

    对于小端系统来说,用结构体表示位域,其排在前面的占字节的低端,排在后面的占字节序的低端。

    例:

    对应结构体为:

    typedef struct tagRTP_HEAD_S {     UINT8  cc:4; /* CSRC count */     UINT8  x:1; /* header extension flag */     UINT8  p:1; /* padding flag */     UINT8  version:2; /* protocol version */     UINT8  pt:7; /* payload type */     UINT8  m:1; /* marker bit */     INT16  seq; /* sequence number */     INT32  ts; /* timestamp */     UINT32 ssrc; /* synchronization source */ }RTP_HEAD_S;

    二、结构体中的位定义     转自:

    在工作中,经常遇到按位(bit)定义结构体 的情况。由于一个字节有8个位,这时,程序员往往对bit的位置产生困惑。现在给出一个例子,来说明位的定义次序。

    #pragma pack(push,1)   typedef struct ST_TEST {     unsigned char    ucA:1;     unsigned char    ucB:1;     unsigned char    ucC:1;     unsigned char    ucD:1;     unsigned char    ucE:1;     unsigned char    ucF:1;     unsigned char    ucG:1;     unsigned char    ucH:1; } ST_TEST; #pragma pack(pop)   #include <string.h> #include <stdio.h> int main(void) {     ST_TEST stTest;     stTest.ucA = 1;     stTest.ucB = 0;     stTest.ucC = 0;     stTest.ucD = 0;     stTest.ucE = 0;     stTest.ucF = 0;     stTest.ucG = 1;     stTest.ucH = 0;       unsigned char ucTest;     memcpy(&ucTest, &stTest, 1);     //没有现成的打印二进制的方法,所以用16进制打印     printf("%x", ucTest);       scanf("%c", &ucTest);     return 0; }  结果是0x41,也就是二进制的0b01000001.可见,定义在一开头的ucA反而落到了最后,而倒数第二的ucG起始在左起正数第二。所以,结构体里定义比特,次序起始是反的。  

    最新回复(0)