Java 使用十六进制表示法的字节[]数组的文字语法。。?

Java 使用十六进制表示法的字节[]数组的文字语法。。?,java,arrays,compiler-construction,hex,literals,Java,Arrays,Compiler Construction,Hex,Literals,编译器似乎对此没有问题(仅限一位数十六进制值): 但不是这个: byte[] rawbytes={0xa, 0x2, 0xff}; 我得到一个“可能的精度损失发现:int必需:字节”错误 我做错了什么?还是一位数十六进制数是一种特殊情况 Java 1.5.x.字节已签名,且0xff=255太大。有效范围为(-128..127) 示例代码: public static void main(String[] args) { byte b = (byte) 0xff; // = -1

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

但不是这个:

byte[] rawbytes={0xa, 0x2, 0xff};
我得到一个“可能的精度损失发现:int必需:字节”错误

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


Java 1.5.x.

字节
已签名,且
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);
}
“0xFF”是十进制值255的
int
文字,不能表示为字节

现在,您需要将其转换为
字节
,以告诉编译器您真正的意思是-1,如下所示:

byte[] rawbytes = { 0xA, 0x2, (byte) 0xFF };
建议添加一个新的字节文字语法(
y
y
后缀),这样您就可以编写:

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

但是,这个建议没有包含在“改进整数文字的综合建议”中,因此我们永远坚持强制转换。

正如另一个回答所说,字节在Java中是有符号类型。范围为-128到127(含)。所以0xff等于-0x01。如果添加手动强制转换,则可以使用0xff而不是-0x01:

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

还有一种可能性是通过声明带有变量参数的helper函数。如果需要声明多字节数组,这可能更可取

示例代码

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
    }
}
publicstaticbyte[]toBytes(int…ints){//helper函数
字节[]结果=新字节[ints.length];
for(int i=0;i
后缀
y
没有出现在Java7版本中。请删除该部分,以免混淆读者。
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
    }
}