我正在尝试编写一个 C 函数,该函数将打印一个由 x 的最低有效字节和 y 的剩余字节组成的单词。例如,如果 x = 0x89ABCDEF 和 y = 0x76543210,这应该给出 0x765432EF,但如何?
问问题
9385 次
2 回答
10
为了操作数据类型中的特定位(或字节),您应该使用按位运算符。
基本的按位运算符是 | (or)、& (and)、^(异或)和 ~(非或补码),它们的工作方式与逻辑运算符 ||、&& 和 ! 非常不同。
使用您的变量 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 组,以查看十六进制如何转换为二进制。
现在,我们需要取消设置 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
花一些时间来熟悉这些操作,你应该不会有任何麻烦。此外,请务必学习其他按位运算符(<<、>>、&=、|= 等)
于 2012-09-12T07:28:52.620 回答
7
你试过这个吗?
inline uint32_t combine(uint32_t x, uint32_t y) {
return (y & 0xffffff00) | (x & 0xff);
}
这是一个示例(请参见此处的结果)。
#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));
}
于 2012-09-11T23:07:23.793 回答