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

mon*_*nny 47 java arrays compiler-construction hex literals

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

byte[] rawbytes={0xa, 0x2, 0xf};
Run Code Online (Sandbox Code Playgroud)

但不是这个:

byte[] rawbytes={0xa, 0x2, 0xff};
Run Code Online (Sandbox Code Playgroud)

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

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

Java 1.5.x.

Hen*_*ann 48

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

byte[] rawbytes={0xa, 0x2, (byte) 0xff};
Run Code Online (Sandbox Code Playgroud)


Eer*_*nen 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
    }
}
Run Code Online (Sandbox Code Playgroud)


And*_*s_D 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);
}
Run Code Online (Sandbox Code Playgroud)


eri*_*son 8

"0xFF"是int十进制值255 的文字,不能表示为字节.

现在,您需要将它转换为a byte来告诉编译器您真正的意思是-1,如下所示:

byte[] rawbytes = { 0xA, 0x2, (byte) 0xFF };
Run Code Online (Sandbox Code Playgroud)

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

byte[] rawbytes = { 0xA, 0x2, 0xFFy };
Run Code Online (Sandbox Code Playgroud)

但是,这个提议没有包含在"改进整体文字的综合提案"中,所以我们永远坚持演员.

  • `y`后缀没有进入Java 7版本.请删除该部分,以免混淆读者. (7认同)