我即将开始处理需要读取字节和创建字符串的事情。正在读取的字节表示 UTF-16 字符串。因此,为了测试一下,我想将 UTF-16 编码的简单字节数组转换为字符串。数组中的前 2 个字节必须表示字节顺序,因此必须是 0xff 0xfe 或 0xfe 0xff。所以我尝试按如下方式创建字节数组:
byte[] bytes = new byte[] {0xff, 0xfe, 0x52, 0x00, 0x6F, 0x00};
但我收到了一个错误,因为 0xFF 和 0xFE 太大,无法放入一个字节中(因为字节在 Java 中是有符号的)。更准确地说,错误是 int 无法转换为字节。我知道我可以通过强制转换显式地从 int 转换为 byte 并实现所需的结果,但这不是我的问题所在。
为了尝试一些东西,我创建了一个字符串并调用 getBytes("UTF-16"),然后打印数组中的每个字节。输出有点令人困惑,因为前两个字节是 0xFFFFFFFE 0xFFFFFFFF,后面是 0x00 0x52 0x00 0x6F。 (显然这里的字节顺序与我上面尝试创建的不同,但这并不重要)。
使用此输出,我决定尝试以相同的方式创建我的字节数组:
byte[] bytes = new byte[] {0xffffffff, 0xfffffffe, 0x52, 0x00, 0x6F, 0x00};
奇怪的是它工作得很好。所以我的问题是,为什么Java允许0xFFFFFF80或更大的整数值自动转换为字节而无需显式转换,但任何等于或大于0x80的值都需要显式转换?