当前位置: 首页 > 面试题库 >

使用按位运算符将多个值打包到一个int中

骆文华
2023-03-14
问题内容

低级别的位操作从来都不是我的强项。在理解以下按位运算符的用例时,我将不胜感激。请考虑…

int age, gender, height, packed_info;

. . .   // Assign values

// Pack as AAAAAAA G HHHHHHH using shifts and "or"
packed_info = (age << 8) | (gender << 7) | height;

// Unpack with shifts and masking using "and"
height = packed_info & 0x7F;   // This constant is binary ...01111111
gender = (packed_info >> 7) & 1;
age    = (packed_info >> 8);

我不确定这段代码将完成什么以及如何完成?为什么使用幻数0x7F?包装和拆包如何完成?

资源


问题答案:

就像评论所说,我们将年龄,性别和身高分成15位,格式为:

AAAAAAAGHHHHHHH

让我们从这一部分开始:

(age << 8)

首先,age具有以下html" target="_blank">格式:

age           = 00000000AAAAAAA

其中每个A可以为0或1。

<< 8将位向左移动8位,并用零填充间隙。这样就得到:

(age << 8)    = AAAAAAA00000000

类似地:

gender        = 00000000000000G
(gender << 7) = 0000000G0000000
height        = 00000000HHHHHHH

现在我们想将它们组合成一个变量。该|运营商的工作原理是看着每一位,并返回1,如果该位是其中一个输入1。所以:

0011 | 0101 = 0111

如果一个输入中的某个位为0,则可以从另一输入中获取该位。望着(age << 8)(gender << 7)height,你会看到,如果一个位为1的其中之一,它为其他的0。所以:

packed_info = (age << 8) | (gender << 7) | height = AAAAAAAGHHHHHHH

现在我们要解压缩位。让我们从高度开始。我们要获取最后7位,而忽略前8位。为此,我们使用&运算符,该运算符仅在两个输入位均为1时才返回1。

0011 & 0101 = 0001

所以:

packed_info          = AAAAAAAGHHHHHHH
0x7F                 = 000000001111111
(packed_info & 0x7F) = 00000000HHHHHHH = height

要确定年龄,我们可以将所有8个位置都推到右侧,然后再按0000000AAAAAAAA。这样age = (packed_info >> 8)

最后,为了获得性别,我们将所有7个位置推到右侧以摆脱身高。然后,我们只关心最后一点:

packed_info            = AAAAAAAGHHHHHHH
(packed_info >> 7)     = 0000000AAAAAAAG
1                      = 000000000000001
(packed_info >> 7) & 1 = 00000000000000G


 类似资料:
  • 我试图在两个数字之间执行位或运算:650510336和2147483648()

  • 问题内容: 我可以使用单个与号代替类似的按位运算符吗?可能会出现什么样的差异,是否有特定的示例可以清楚地说明此问题? 问题答案: 单身人士将始终检查这两个条件。如果双精度值判断为false,则它将在第一个条件之后停止。如果确实只需要1个2的条件为真或假,则使用2是“短路”状态检查的一种方法。 例如: 如果为,则第一个条件将失败,并且不会费心检查它的值。这是避免空指针的一种方法。 与和两个操作数始终

  • 这很有魅力: 但如果我想按多个单词搜索,它将不返回任何内容,例如: 当我使用CURL时,我通过将添加到我的JSON属性来解决这个问题: 卷曲-XGET“http://localhost:9200/_search“-d”{“查询”:{“匹配”:{“字段”:{“查询”:“word\u 1 word\u 2”,““模糊性”:“自动”,““运算符”:“和”}}}}}” 我如何在Java中实现这一点?

  • 问题内容: 我收到编译器错误: 如果我不是完全错误,则二进制AND的结果与最长的操作数一样长。为什么结果是整数? 如果我想做空,会不会有表现上的损失? 问题答案: 如果我不是完全错误,则二进制AND的结果与最长的操作数一样长。为什么结果是整数? 因为Java语言规范说非长整数算法的结果始终是int。它可能写在的事实,32位CPU一样,内部的工作无论如何确认的方式-他们实际上不 具有 一种方法做算术

  • 问题内容: 我有一个filename(),然后需要用“-” 分配给文件类型。目前,无论文件类型如何,我总是会得到。 为什么使用OR运算符的if语句不起作用? 问题答案: 该逻辑 (OR)运算符 如您预期的工作不工作。该运营商始终计算结果为布尔TRUE或FALSE。因此,在您的示例中,您的字符串将转换为布尔值,然后进行比较。 如果声明: 归结为: 要解决此问题并使代码按您希望的方式工作,可以使用其他

  • 问题内容: 为什么按位操作打印-1?在二进制中,不为0应该为1。为什么呢? 问题答案: 你实际上很亲密。 在二进制中,不为0应该为1 是的,当我们谈论一点时,这是绝对正确的。 但是,其值为0实际上是全零的32位!将所有32个零转换为32个零。 这是的补码表示形式。 类似地: 也就是说,对于32位无符号二进制补码表示,。 进一步阅读: 补码 这是Java(以及其他系统)用来表示带符号的数字位的系统