方法一:
#define MAKE_WORD_DEF(a3,a2,a1,a0) ((BYTE)a3<<24 | (BYTE)a2<<16 | (BYTE)a1<<8 | (BYTE)a0)
#define EXTRACT_WORD_BYTE(iByte,dWord) ((BYTE)( dWord >> ((iByte%4)<<3 )))
WORD DBUF = MAKE_DWORD_DEF(1,2,3,4); //结果 DBUF = 0x12345678
BYTE BBUF = EXTRACT_DWORD_BYTE(1,DBUF); //取出的是 a1 , 结果 BBUF=3
方法二:
写入:0x12345678
WORD wBuf = 0;
((BYTE)&wBuf) = 0x12;
(((BYTE)&wBuf)+1) = 0x34;
(((BYTE)&wBuf)+2) = 0x56;
(((BYTE)&wBuf)+3) = 0x78;
本文介绍了两种使用位操作进行字节提取和组装的方法。方法一利用宏定义实现字节的组合和提取,通过位移和按位或操作将四个字节组合成一个DWORD,并从中提取特定位置的字节。方法二则直接通过指针操作,将每个字节逐个写入到目标变量中,实现了高效的数据字节顺序转换。
3万+

被折叠的 条评论
为什么被折叠?



