编译器似乎对此没问题(仅限单位数字十六进制值):
byte[] rawbytes={0xa, 0x2, 0xf};
但不是这个:
byte[] rawbytes={0xa, 0x2, 0xff};
我收到“发现可能的精度损失:需要 int :字节”错误?
我做错了什么 - 还是个位数的十六进制数字是一种特殊情况?
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”是十进制值 255 的
int
文字,它不能表示为字节。
现在,您需要将其转换为
byte
来告诉编译器您真正的意思是 -1,如下所示:
byte[] rawbytes = { 0xA, 0x2, (byte) 0xFF };
有人建议在
Java 7 中添加新的字节文字语法(
y
或
Y
后缀)。 那么你就可以写:
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);
}