编译器似乎没问题(仅限单个数字十六进制值):
byte[] rawbytes={0xa, 0x2, 0xf};
但不是这样:
byte[] rawbytes={0xa, 0x2, 0xff};
我得到“可能的精度损失:int required:byte”错误?
我做错了什么 - 或者是单个数字的十六进制数字是一个特例吗?
Java 1.5.x。
答案 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.添加一个新的字节文字语法(y
或Y
后缀)然后你就可以写了:
byte[] rawbytes = { 0xA, 0x2, 0xFFy };
然而,这个提议没有包含在“改进整数文字的综合提案”中,所以我们永远坚持使用演员。