我试图编写一个C函数来打印一个由最不重要的单词组成的单词 x的字节和y的剩余字节。例如,如果x = 0x89ABCDEF且y = 0x76543210,这应该给0x765432EF,但是如何?
答案 0 :(得分:9)
为了操纵数据类型中的特定位(或字节),您应该使用逐位运算符。
基本的逐位运算符是| (或),& (和),^(独占或)和〜(NOT或补充),它们的工作方式与逻辑运算符||,&&,和。!
完全不同使用你的变量x = 0x89ABCDEF和y = 0x76543210,让我们逐步解决:
首先,这些是二进制x和y的值:
x = 1000 1001 1010 1011 1100 1101 1110 1111
y = 0111 0110 0101 0100 0011 0010 0001 0000
我将32位分成4组,看看hex如何转换为二进制。
现在,除了x中的最后一个字节外,我们需要取消设置:操作(x& 0xFF)
x = 1000 1001 1010 1011 1100 1101 1110 1111
0xFF = 0000 0000 0000 0000 0000 0000 1111 1111
--------------------------------------------------
x & 0xFF = 0000 0000 0000 0000 0000 0000 1110 1111
我们需要取消设置y的最后一个字节:操作(y& ~0xFF)
y = 0111 0110 0101 0100 0011 0010 0001 0000
~0xFF = 1111 1111 1111 1111 1111 1111 0000 0000 (~ flips all bits)
-----------------------------------------------------
(y & ~0xFF) = 0111 0110 0101 0100 0011 0010 0000 0000
现在,使用“或”操作组合我们的结果:(x& 0xFF)| (y& ~0xFF)
(x & 0xFF) = 0000 0000 0000 0000 0000 0000 1110 1111
(y & ~0xFF) = 0111 0110 0101 0100 0011 0010 0000 0000
------------------------------------------------------------------
(x & 0xFF) | (y & ~0xFF) = 0111 0110 0101 0100 0011 0010 1110 1111
Which in hex is------------7----6----5----4----3----2----E----F
花一些时间熟悉这些操作,你不应该有任何麻烦。此外,请务必学习其他按位运算符(<<,>>,& =,| =等)
答案 1 :(得分:7)
你试过这个吗?
inline uint32_t combine(uint32_t x, uint32_t y) {
return (y & 0xffffff00) | (x & 0xff);
}
以下是一个示例(请参阅结果here)。
#include <inttypes.h>
#include <stdio.h>
inline uint32_t combine(uint32_t x, uint32_t y) {
return (y & 0xffffff00) | (x & 0xff);
}
main() {
printf("%" PRIx32 "\n", combine(0x89abcdef, 0x76543210));
}