java位移运算

1、java将负整数转成二进制

  这里以8位为例,只是为了表明过程,实际中java的int类型是4byte,也就是32位。二进制的首位是符号位,0表示正数,1表示负数,在java中,会对负数进行取反加一操作,进而计算出实际的十进制值。如10101010,此8位的二进制数首位是1,表示负数,所以对后面的七位进行取反加一操作,即0101010-->1010110,换成十进制的数就是86,再加上首位的1表示负数,结果就是-86。

2、位移运算

  1)正数的右移:如10 >> 2,左边自动补0,右边移出位舍弃,即00001010 --> 00000010,结果是2,实际的意思是,每向右移动一位,就相当于除以2,小数舍弃,即10/2/2=2.5,舍弃小数,结果就是2。

  2)正数的左移:如10 << 2,右边自动补0,左边移出位舍弃,即00001010 --> 00101000,结果是40,实际的意思是,每向左移动一位,就相当于乘以2,即10*2*2=40。

  3)负数的右移:如-2 >> 2,由于二进制的首位为符号位,负数在右移过程中,为了保持负数的特性,所以左边会自动补1而不是0,即11111110--> 11111111,结果为-1。

  4)负数的左移:负数的左移与正数的左移一致,在右边自动补0。

  5)无符号的右移:如-2 >>> 2,对于负数的右移在左边自动补1,但是对于无符号的右移,左边是自动补0,即11111110 -- > 00111111,结果为63。所谓的无符号右移,就是不考虑正数还是负数,左边一律补0。

3、想一想为什么没有无符号左移?个人理解,因为不管正数还是负数,左移都是在右边补0。

原文地址:https://www.cnblogs.com/1ning/p/6890894.html