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 @   达摩院的BLOG  阅读(353)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
历史上的今天:
2020-04-27 宿主CentOS7环境下docker中nginx的安装
点击右上角即可分享
微信分享提示