我有一个二进制数,如下所示:
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)...
谢谢!
答案 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
然后将这些位移入最低有效位以存储到a
,b
,c
和d
(无符号位移位):
(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);