简体   繁体   English

从2或4个字节转换为有符号/无符号short / int

[英]Convert from 2 or 4 bytes to signed/unsigned short/int

I have to convert bytes to signed/unsigned int or short. 我必须将字节转换为signed / unsigned int或short。

The methods below are correct? 以下方法是正确的吗? Which is signed and which unsigned? 哪个是签名的,哪个是未签名的?

Byte order: LITTLE_ENDIAN 字节顺序:LITTLE_ENDIAN

public static int convertTwoBytesToInt1(byte b1, byte b2) {
    return (int) ((b2 << 8) | (b1 & 0xFF));
}

VS. VS.

public static int convertTwoBytesToInt2(byte b1, byte b2) {
    return (int) (( (b2 & 0xFF) << 8) | (b1 & 0xFF));
}

and

public static int  convertFourBytesToInt1(byte b1, byte b2, byte b3, byte b4){
    return (int) ((b4<<24)+(b3<<16)+(b2<<8)+b1);
}

VS. VS.

public static int  convertFourBytesToInt2(byte b1, byte b2, byte b3, byte b4){
    return (int) (( (b4 & 0xFF) << 24) | ((b3 & 0xFF) << 16) | ((b2 & 0xFF) << 8) | (b1 & 0xFF));
}

I'm interested only in this conversion forms. 对这种转换形式感兴趣。 Thanks! 谢谢!

The first method ( convertXXXToInt1() ) of each pair is signed, the second ( convertXXXToInt2() ) is unsigned. 每对的第一个方法( convertXXXToInt1() )是有符号的,第二个( convertXXXToInt2() )是无符号的。

However, Java int is always signed, so if the highest bit of b4 is set, the result of convertFourBytesToInt2() will be negative, even though this is supposed to be the "unsigned" version. 但是,Java int始终是有符号的,因此如果设置了b4的最高位,则convertFourBytesToInt2()的结果将为负数,即使这应该是“无符号”版本。

Suppose a byte value, b2 is -1, or 0xFF in hexadecimal. 假设一个byte值, b2为-1,或十六进制为0xFF。 The << operator will cause it to be "promoted" to an int type with a value of -1, or 0xFFFFFFFF. <<运算符将使其“提升”为值类型为-1或0xFFFFFFFF的int类型。 After the shift of 8 bits, it will be 0xFFFFFF00, and after a shift of 24 bytes, it will be 0xFF000000. 在8位移位后,它将是0xFFFFFF00,在移位24字节后,它将是0xFF000000。

However, if you apply the bitwise & operator, the higher-order bits will be set to zero. 但是,如果应用按位&运算符,则高位位将设置为零。 This discards the sign information. 这会丢弃标志信息。 Here are the first steps of the two cases, worked out in more detail. 以下是这两个案例的第一步,更详细地说明了这一点。

Signed: 签:

byte b2 = -1; // 0xFF
int i2 = b2; // 0xFFFFFFFF
int n = i2 << 8; // 0x0xFFFFFF00

Unsigned: 无符号:

byte b2 = -1; // 0xFF
int i2 = b2 & 0xFF; // 0x000000FF
int n = i2 << 8; // 0x0000FF00

There is a problem with the 4-byte unsigned conversion, because it doesn't fit into an int. 4字节无符号转换存在问题,因为它不适合int。 The routines below work correctly. 以下例程正常工作。

public class IntegerConversion
{
  public static int convertTwoBytesToInt1 (byte b1, byte b2)      // signed
  {
    return (b2 << 8) | (b1 & 0xFF);
  }

  public static int convertFourBytesToInt1 (byte b1, byte b2, byte b3, byte b4)
  {
    return (b4 << 24) | (b3 & 0xFF) << 16 | (b2 & 0xFF) << 8 | (b1 & 0xFF);
  }

  public static int convertTwoBytesToInt2 (byte b1, byte b2)      // unsigned
  {
    return (b2 & 0xFF) << 8 | (b1 & 0xFF);
  }

  public static long convertFourBytesToInt2 (byte b1, byte b2, byte b3, byte b4)
  {
    return (long) (b4 & 0xFF) << 24 | (b3 & 0xFF) << 16 | (b2 & 0xFF) << 8 | (b1 & 0xFF);
  }

  public static void main (String[] args)
  {
    byte b1 = (byte) 0xFF;
    byte b2 = (byte) 0xFF;
    byte b3 = (byte) 0xFF;
    byte b4 = (byte) 0xFF;

    System.out.printf ("%,14d%n", convertTwoBytesToInt1 (b1, b2));
    System.out.printf ("%,14d%n", convertTwoBytesToInt2 (b1, b2));

    System.out.printf ("%,14d%n", convertFourBytesToInt1 (b1, b2, b3, b4));
    System.out.printf ("%,14d%n", convertFourBytesToInt2 (b1, b2, b3, b4));
  }
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM