如何简化这种二进制到java类型的代码?

我得到两个java字节作为输入,共同表示一个16位有符号整数。我需要将它转换为一个单一的java整数(当然,签名)。我想出了一个“丑陋的”解决方案,其中包括转换为int,然后转换为short,然后转换为int。有更短更优雅的方式吗? 我的代码如下:如何简化这种二进制到java类型的代码?

public int convert(byte b1, byte b2){ 

int i1 = (int) (((b2 << 8) + (b1 & 0xFF)) & 0x0000FFFF);

short s1 = (short) i1;

int i2 = (int) s1;

return i2;

}

回答:

这似乎符合您转换器 - 不能确定它是简单,但它肯定是少冗长。

public int convert2(byte b1, byte b2) { 

return new BigInteger(new byte[]{b2,b1}).intValue();

}

回答:

以下是等效的:

return (short) ((b2 << 8) | (b1 & 0xFF)); 

byte具有足够小的范围内,这是实际中测试该等价为b1b2所有可能的值:

byte b1 = Byte.MIN_VALUE; 

do {

byte b2 = Byte.MIN_VALUE;

do {

assertEquals(convert(b1, b2), convertEquivalent(b1, b2));

} while (b2++ != Byte.MAX_VALUE);

} while (b1++ != Byte.MAX_VALUE);

Ideone demo

回答:

@AndTurner可能是您寻求的解决方案。

但是,如果涉及字节数组或某个文件通道(存储器映射文件),输入流,则可以使用ByteBuffer。

byte[] bytes = ... 

ByteBuffer buf = ByteBuffer.wrap(bytes).order(ByteOrder.LITTLE_ENDIAN);

...

short n = buf.readShort(); // Sequential

short m = buf.readShort(354L); // Direct access

以上是 如何简化这种二进制到java类型的代码? 的全部内容, 来源链接: utcz.com/qa/261671.html

回到顶部