如何在C中获取变量的最低有效字节

问题描述 投票:2回答:2

我正在尝试编写一个C函数,它将打印一个由x的最不重要字节和y的剩余字节组成的字。例如,如果x = 0x89ABCDEF且y = 0x76543210,这应该给出0x765432EF,但是如何?

c byte
2个回答
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

花些时间熟悉这些操作,你不应该有任何麻烦。另外,确保学习其他按位运算符(<<,>>,&=,| =等)


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));
}
© www.soinside.com 2019 - 2024. All rights reserved.