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。

            对于带有小数的负数的右移:其实就是除以2舍弃小数,然后减1。

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

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

对于正数而言,>>和>>>没区别。

对于负数而言,-2 >>> 1,结果是2147483647(Integer.MAX_VALUE),-1 >>> 1,结果是2147483647(Integer.MAX_VALUE)

-2 >>> 2 等于 Integer.MAX_VALUE / 2

注意:没有无符号左移运算符

posted @ 2022-04-27 15:16  达摩院的BLOG  阅读(349)  评论(0编辑  收藏  举报