java中byte转int时&0xff的意义

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

&0xff的目的是保留二进制的原值,但会改变十进制的数

猜你喜欢

转载自blog.csdn.net/DDKii/article/details/86679989
今日推荐