我将开始处理需要读取字节并创建字符串的内容。读取的字节代表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的任何值都需要显式强制转换?

最佳答案

这里要记住的关键是Java中的int是一个带符号的值。当您分配0xffffffff(即2^32 -1)时,这将转换为带符号的值-1的int - int实际上不能表示与0xffffffff一样大的正数。

因此,对于小于0x80且大于0xFFFFFF80的值,所得的int值在-128到127之间,可以明确地表示为byte。超出此范围的任何事物都不可能,并且需要强制使用显式强制转换,从而在过程中丢失数据。

关于Java将int隐式转换为字节,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/1935699/

10-10 01:29
查看更多