2

我有一个看起来像这样的二进制数:

00000000 00000000 00000011 00001101 = 781 整数值 = 整数名称“打包”

我如何能够在java中使用逐位将它们中的每一个提取为单独的整数值。如下所示:

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)...

2天前为我回答了这个问题,它工作得很好,但现在它坏了......我不知道为什么......这是我用来做这个的方法:

public static int 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 x = 781;
System.out.println(getNthByte(3, x)); (Which should give me 00001101, in integer value)

我打印以下内容:

0

为什么?昨天这对我来说很好......但我注意到当我这样做时:

System.out.println(getNthByte(5, x));

它给了我第三点:

3

哪个是正确的...

tl; dr 这种方法昨天运行良好,现在一切都搞砸了,我需要帮助修复它,或者可能是我的错误?我不知道..昨天我输入了getNthByte(3,x),它给了我与00001101相关的正确整数值......

任何帮助表示赞赏..也许该方法有问题?还是只有我?

4

3 回答 3

5

在 Java 中,你必须处理二进制数据,一个词应该立即浮现在你的脑海中ByteBuffer

final ByteBuffer buf = ByteBuffer.allocate(4); // sizeof(int)
buf.putInt(yourInt);

返回第 n 个字节现在很简单:

return (int) buf.get(byteIndex);

请注意,您假设您的整数是大端顺序;幸运的是,您是对的:Java 就是这种情况。总是。无论底层架构的字节顺序如何。

于 2013-06-17T20:50:44.157 回答
1

如所写,您的功能正在运行,并且正在产生正确的答案。第 3 个字节(从右边开始)是00000000. 由于您将数字右移 8*n 位,然后将其与 相与0xFF,您将得到您想要的。

当您使用大于 32 (5*8 = 40) 的数字进行右移时,编译器似乎只取该数字的后五位(或者,如果您喜欢,40%32 = 8)并用它进行右移。与将数字右移8 位,然后查看底部 8 位的方法getNthByte(5, x)相同。getNthByte(5%4, x)getNthByte(1, x)x

我很困惑为什么你认为getNthByte(5,x)应该返回第三个字节。你是怎么从五到三的?或者它是一个错字?

我想你刚刚忘记了你的功能做了什么。

于 2013-06-17T20:28:26.710 回答
1

你已经传入了3你想要的字节,但是根据你的行

int shifted = packed >> (8 * n);

这将向右移动 24 位,所以它得到的是第一个字节,而不是最后一个字节。

要翻转字节顺序的概念,请n3乘以之前减去8

int shifted = packed >> (8 * (3 - n));

因此,传入 3 将导致 0 位的移位,以获得最低有效字节(00001101),而不是最高有效字节。

或者,如果您的行确实代表了您想要的顺序,只需传入0

System.out.println(getNthByte(0, x));
于 2013-06-17T20:32:52.147 回答