0

我正在尝试解码某人的字节数组,但我被困在这部分:

&lt state &gt ::= "01" <i>(2 bits) for A</i>
                   "10" <i>(2 bits) for B</i>
                   "11" <i>(2 bits) for C</i>

我认为这希望我查看下一个字节的下 2 位。这是否意味着字节的最低或最高有效数字?我想如果这意味着最不重要的,我会扔掉最后 6 位?

我发现这段代码用于查看字节的位:

for (int i = 0; i < byteArray.Length; i++)
{
   byte b = byteArray[i];
   byte mask = 0x01;
   for (int j = 0; j < 8; j++)
   {
      bool value = b & mask;
      mask << 1;
   }
}

有人可以扩展这到底是做什么的吗?

4

1 回答 1

1

只是给你一个开始:

要提取字节的各个位,请使用“&”,称为按位与运算符。按位与运算的意思是“保留两侧设置的所有位”。例如,当您计算两个字节的按位与时,例如 00000011 和 00000010,则结果为 00000010,因为只有倒数第二位的位设置在两侧。

在 java 编程语言中,同样的例子看起来像这样:

int a = 3;
int b = 2;
int bitwiseAndResult = a & b; // bitwiseAndResult will be equal to 2 after this

现在要检查是否设置了某个 int 的第 n 位,您可以这样做:

int intToExamine = ...;
if ((intToExamine >> n)) & 1 != 0) {
    // here we know that the n'th bit was set
}

>> 称为位移运算符。它只是将位从左向右移动,如下所示:00011010 >> 2 将得到结果 00000110。

所以从上面你可以看到,为了提取某个值的第 n 位,你首先将第 n 位移动到位置 0(注意第一位是位 0,而不是位 1),然后使用按位和运算符 (&) 仅保留该位 0。

以下是按位和位移运算符的一些简单示例: http ://www.tutorialspoint.com/java/java_bitwise_operators_examples.htm

于 2013-04-26T17:11:00.093 回答