编译器似乎对这个没有问题(仅适用于单个十六进制数字):
byte[] rawbytes={0xa, 0x2, 0xf};
但不包括这个:
byte[] rawbytes={0xa, 0x2, 0xff};
我遇到了一个"Possible Loss of Precision found : int required : byte"的错误?
我做错了什么 - 还是单个十六进制数字是特殊情况?
Java 1.5.x。
编译器似乎对这个没有问题(仅适用于单个十六进制数字):
byte[] rawbytes={0xa, 0x2, 0xf};
但不包括这个:
byte[] rawbytes={0xa, 0x2, 0xff};
我遇到了一个"Possible Loss of Precision found : int required : byte"的错误?
我做错了什么 - 还是单个十六进制数字是特殊情况?
Java 1.5.x。
正如其他答案所述,byte在Java中是一个有符号类型。它的范围从-128到127(包括两端)。因此0xff等于-0x01。如果您添加手动转换,可以使用0xff代替-0x01:
byte[] rawbytes={0xa, 0x2, (byte) 0xff};
如果需要声明多个字节数组,则可以通过声明一个具有可变参数的帮助函数来实现。这可能更可取。
示例代码:
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
}
}
\"0xFF\"是一个int
的字面量,表示十进制值255,这个值不能被表示为一个字节。
目前,你需要将它转换成一个byte
类型,告诉编译器你真正想要的是-1,就像这样:
byte[] rawbytes = { 0xA, 0x2, (byte) 0xFF };
y
或Y
后缀)到Java 7.。这样,您就可以编写以下代码:byte[] rawbytes = { 0xA, 0x2, 0xFFy };
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);
}
y
后缀。请删除这部分内容,这样可以避免给读者造成困惑。 - Natix