Java 位运算(移位、位与、或、异或、非)

在Java语言中,二进制数使用补码表示,最高位为符号位,正数的符号位为0,负数为1。补码的表示需要满足如下要求。  

(1)正数的最高位为0,其余各位代表数值本身(二进制数)。  

(2)对于负数,通过对该数绝对值的补码按位取反,再对整个数加1。 

位移运算符:

<< 左位移(左移运算是将操作数二进制值逐位左移若干位,左移过程中符号位不变 ,高位溢出并舍弃,低位补0

>>右位移 (右移运算是将操作数二进制值逐位右移若干位,右移过程中符号位不变 ,低位溢出并舍弃,并用符号位补溢出的高位[即负数补1,正数补0])

>>> 无符号右位移(无符号右移运算是将操作数所有二进制值逐位右移若干位,包括最高位符号位,也跟着右移,低位溢出并舍弃高位补0;注意,无符号右移(>>>)中的符号位(最高位)也跟着变)

逻辑运算符:

&  按位与 (与运算是将参与用算两个二进制数进行&用算,如果两个二进制位都是1,则与用算的结果为1,其他全都为0)

 |  按位或  (或用算是将参与用算两个二进制数进行 | 用算,如果两个二进制位都是0,则与运算的结果为0,其他全都为1,即只要其中一个数字的二进制位是1,这个二进制位的运算结果就为1)

^  按位异或(异或^运算是将参与运算的两个二进制进行“异或”运算,如果二进制位相同,则结果为1,否则为0)

~  取反(取反运算是只针对一个数据进行操作,如果二进制是0,则取反为1,如果二进制是1,则取反为0)

 

参考:https://blog.csdn.net/black_bird_cn/article/details/80171652

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值