- 首先,我们知道,在java中byte的长度为1字节,int为长度为4字节;
- 当byte转为int时,多余的三个字节将在高位补充,也就补充了24个bit位,而补位原则是根据符号为补充,也就是说正数补0负数补1
- 这样做造成的结果就是如果一个byte类型的值为负数,转为int后多出的24位将为1,如下,-8的原反补:
二进制类型 ==> byte类型存储 ==> int类型存储
原码 [10001000]
反码 [11110111]
补码 [11111000] [11111111 11111111 11111111 11111000]
- 然后我们对比两个类型的补码[11111000],[11111111 11111111 11111111 11111000],虽然表示的十进制是一样的,但很明显,它的二进制失真了,理想的情况应当是[00000000 00000000 00000000 11111000]
- 所以最后需要引入 &0xff ,
&是位与运算,计算原则是相同位置都为1则为1,否则为0;
0xff是16进制中的[11111111]0xff是16进制中的[11111111] - 最终的计算结果为:
11111111 11111111 11111111 11111000
11111111 <------0xff仅表示8位,前面没有则认为是0
---------------------------------------
00000000 00000000 00000000 11111000
&0xff的目的是保留二进制的原值,但会改变十进制的数