使用十六进制表示法的 byte[] 数组的文字语法..?

问题描述 投票:0回答:4

编译器似乎对此没问题(仅限单位数字十六进制值):

byte[] rawbytes={0xa, 0x2, 0xf};

但不是这个:

byte[] rawbytes={0xa, 0x2, 0xff};

我收到“发现可能的精度损失:需要 int :字节”错误?

我做错了什么 - 还是个位数的十六进制数字是一种特殊情况?

Java 1.5.x.

java arrays hex literals
4个回答
58
投票

正如其他人已经回答的那样,byte是Java中的有符号类型。范围是从 -128 到 127(含)。所以0xff等于-0x01。如果添加手动转换,则可以使用 0xff 而不是 -0x01:

byte[] rawbytes={0xa, 0x2, (byte) 0xff};

15
投票

还有另一种可能性,即使用变量参数声明辅助函数。如果您需要声明多个字节数组,这可能更可取。

示例代码

public static byte[] toBytes(int... ints) { // helper function
    byte[] result = new byte[ints.length];
    for (int i = 0; i < ints.length; i++) {
        result[i] = (byte) ints[i];
    }
    return result;
}

public static void main(String... args) {

    byte[] rawbytes = toBytes(0xff, 0xfe); // using the helper

    for (int i = 0; i < rawbytes.length; i++) {
        System.out.println(rawbytes[i]); // show it works
    }
}

9
投票

“0xFF”是十进制值 255 的

int
文字,它不能表示为字节。

现在,您需要将其转换为

byte
来告诉编译器您真正的意思是 -1,如下所示:

byte[] rawbytes = { 0xA, 0x2, (byte) 0xFF };

有人建议在

Java 7 中添加新的字节文字语法(
y
Y 后缀)。 那么你就可以写:

byte[] rawbytes = { 0xA, 0x2, 0xFFy };

但是,该提案并未包含在“改进整数文字的综合提案”中,因此我们永远被强制转换所困扰。


8
投票

byte
已签名且
0xff = 255
太大。有效范围为 (-128 .. 127)。

示例代码:

public static void main(String[] args) {
    byte b = (byte) 0xff;    // = -1
    int i = b;               // = -1
    int j = b & 0xff;        // = 255

    System.out.printf("b=%s, i=%s, j=%s", b,i,j);
}
© www.soinside.com 2019 - 2024. All rights reserved.