Literal语法对于使用Hex表示法的byte []数组..?

时间:2010-08-18 19:43:23

标签: java arrays compiler-construction hex literals

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

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

但不是这样:

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

我得到“可能的精度损失:int required:byte”错误?

我做错了什么 - 或者是单个数字的十六进制数字是一个特例吗?

Java 1.5.x。

4 个答案:

答案 0 :(得分:46)

正如另一个已经说过的那样,byte是Java中的签名类型。范围从-128到127(含)。所以0xff等于-0x01。如果添加手动转换,则可以使用0xff而不是-0x01:

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

答案 1 :(得分:12)

通过使用可变参数声明辅助函数,还有一种可能性。如果需要声明多个字节数组,这可能更好。

示例代码

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
    }
}

答案 2 :(得分: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);
}

答案 3 :(得分:8)

“0xFF”是十进制值255的int字面值,不能表示为字节。

现在,您需要将其强制转换为byte,告诉编译器您的意思是-1,如下所示:

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

建议在Java 7.添加一个新的字节文字语法(yY后缀)然后你就可以写了:

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

然而,这个提议没有包含在“改进整数文字的综合提案”中,所以我们永远坚持使用演员。