从二进制数据中提取某些位

时间:2013-06-13 00:33:29

标签: java binary extract bit-manipulation bit

我有一个二进制数,如下所示:

00000000 00000000 00000011 00001101  =  781 integer value  = integer name "packed"

如何在java中使用bit wise提取每个值作为单独的整数值。如下所示:

int a = (function) = 00000000;
int b = (function) = 00000000;
int c = (function) = 00000011;
int d = (function) = 00001101;

如果你能看到我在那里做什么..我想把前8个变为一个整数,接下来变成第二个整数,依此类推......我认为你在java中使用了一点点但我完全不确定。任何帮助表示赞赏。对不起,我对这种事情全新,真的需要帮助,谢谢!基本上(函数)应该等于这样的东西:

packed >> 5; (I know this isn't nearly right that is why i am needing help on this)...

谢谢!

3 个答案:

答案 0 :(得分:5)

你是对的,这里需要按位操作。

首先,使用掩码仅隔离您感兴趣的位,关闭所有其他位:

value & 0xFF000000  // isolate most significant 8 bits
value & 0x00FF0000  // isolate next 8 bits
value & 0x0000FF00  // isolate next 8 bits
value & 0x000000FF  // isolate least significant  8 bits

然后将这些位移入最低有效位以存储到abcd无符号位移位):

(value & 0xFF000000) >>> 24 // Shift bits 24-31 to bits 0-7
(value & 0x00FF0000) >>> 16 // Shift bits 16-23 to bits 0-7
(value & 0x0000FF00) >>> 8  // Shift bits 8-15 to bits 0-7
(value & 0x000000FF)        // No need to shift the last one!

答案 1 :(得分:4)

这可以通过使用掩码执行按位与运算,然后进行位移来实现。掩码只是一个数字,其中您不感兴趣的所有位都设置为零。它掩盖你不关心的位。

int BYTE_ONE_MASK   = 0xFF;
int BYTE_TWO_MASK   = 0xFF00;
int BYTE_THREE_MASK = 0xFF0000;
int BYTE_FOUR_MASK  = 0xFF000000;

除了最不重要的字节之外的所有字节都需要移位:

int a = (val & BYTE_ONE_MASK);
int b = (val & BYTE_TWO_MASK) >> 8;
int c = (val & BYTE_THREE_MASK) >> 16;
int d = (val & BYTE_FOUR_MASK) >> 24;

这可以概括为如下函数:

  // Assuming the first byte is n = 0.
  public static int getByte(int val, int n) {
    int shift = n * 8;
    int mask = 0xFF << shift;
    return (val & mask) >> shift;
  }

答案 2 :(得分:3)

尝试这样的事情:

public byte getNthByte(int n, int packed) {
    // shift the desired bits into the last 8 bits
    int shifted = packed >> (8 * n);
    // and now get those bits
    int masked = 0x000000FF & shifted;
    return masked;
}

然后

int a = getNthByte(3);
int b = getNthByte(2);
int c = getNthByte(1);
int d = getNthByte(0);