Java中移位操作运算符的理解

java中的移位运算符有三种:

1、 <<: 左移

2、 >>: 右移

3、 >>>: 无符号右移

使用方法:左移就是将左边的操作数在内存中的二进制数据左移指定的位数,左边移空的部分补零,右移:如果最高位是0,空位就填0,如果最高位是1,空位就填1。无符号右移无论最高位是什么,空位都补零。

数据在内存中以补码的形式存储

左移和右移的数学意义:

对于左移,对于整型a,  a<<n=a*2^n(前提是结果在整型的范围之内),对于右移 正的整型a,  a>>n=a/2^n,对于负的整型a,a>>n=-(|a|/2^n+1);

为什么对于右移,正数和负数的结果不一样呢?

我们可以看一个例子:

 

package sort;

public class sort1 {

    public static void main(String[] args) {
        // TODO Auto-generated method stub

    int a=-123;
    System.out.println("原二进制位:"+Integer.toBinaryString(a));
    int b=a>>2;
    System.out.println("右移两位结果为:"+b);
    System.out.println("右移后二进制位:"+Integer.toBinaryString(b));
    int c=123;
    System.out.println("原二进制位:"+Integer.toBinaryString(c));
    int d=c>>2;
    System.out.println("右移后的结果为:"+d);
    System.out.println("右移后二进制位:"+Integer.toBinaryString(d));
    }
}

 

 

运行结果为:

 

对于123,其二进制数为0  1111011,右移两位相当于把0  111000右移两位,而0  111000的十进制为120,所以结果为120/4=30;

对于-123,其二进制数为1  0000101,右移两位相当于把1  0000100右移两位,而1  0000100的十进制为-124,所以结果为-124/4=-31。

 

转载于:https://www.cnblogs.com/qingergege/p/5687306.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值