java位移符号 << 、>>理解

本文解析了Java中的位运算符(<<、>>、>>>)的工作原理,包括左移的乘幂效果、右移的区别,并通过实例说明了与(&)和或(|)在二进制中的应用。重点讲解了位操作在编码和性能优化中的作用。
摘要由CSDN通过智能技术生成

首先试猜一下以下变量的值是多少

static final int FLAG_IN_USE = 1 << 0;
static final int FLAG_IN_USE = 1 << 1;
static final int FLAG_IN_USE = 1 << 2;
static final int FLAG_IN_USE = 1 << 3;
static final int FLAG_IN_USE = 1 << 4;

运行结果 分别是

static final int FLAG_IN_USE = 1 << 0;	// 1
static final int FLAG_IN_USE = 1 << 1;	// 2
static final int FLAG_IN_USE = 1 << 2;	// 4
static final int FLAG_IN_USE = 1 << 3;	// 8
static final int FLAG_IN_USE = 1 << 4;	// 16

再举例

static final int FLAG_IN_USE = 3 << 0;	// 3 
static final int FLAG_IN_USE = 3 << 1;	// 6
static final int FLAG_IN_USE = 3 << 2;	// 12
static final int FLAG_IN_USE = 3 << 3;	// 24
static final int FLAG_IN_USE = 3 << 4;	// 48

结论:(<<) 左移1位,相当于 乘以2 也就是2的一次方,以此类推,<< 2 相当于乘以 4 也就是2的2次方,<< 2 相当于乘以 8 也就是2的3次方

结论 :(>>)右移1位,相当于 除以2 也就是2的一次方,以此类推,<< 2 相当于除以 4 也就是2的2次方,<< 2 相当于除以 8 也就是2的3次方

拓展:

(<<) 代表有符合左移 不分正负,低位补0

//2的原码:0000 0010,2的反码:0000 0010,2的补码:0000 0010,补码左移2位后为0000 1000,对应值为8
System.out.println(2<<2);//8

//-2的原码:1000 0010,-2的反码:1111 1101,-2的补码:1111 1110,补码左移2位后为1111 1000,对应的原码为1000 1000,对应值为-8
System.out.println(-2<<2);//-8

(>>) 代表有符合右移, 如果该数为正,则最高位补0,如果为负,则最高位补1

//4的原码:0000 0100,4的反码:0000 0100,4的补码:0000 0100,补码右移2位后为0000 0001,对应值为0
System.out.println(4>>2);//1

//-4的原码:1000 0100,-4的反码:1111 1011,-4的补码:1111 1100,补码右移2位后为1111 1111,对应的原码为1000 0001,对应的值为-1
System.out.println(-4>>2);//-1

(>>>) 代表无符合右移,逻辑右移,无论该数为整数还是负数,右移后最高位都补0

//4的原码:0000 0100,4的反码:0000 0100,4的补码:0000 0100,补码右移2位后为0000 0001,对应值为0
System.out.println(4>>>2);//1

//java中int为32位,
-4的原码为:1000 0000  0000 0000  0000 0000  0000 0100
-4的反码为:1111 1111  1111 1111  1111 1111  1111 1011
-4的补码为:1111 1111  1111 1111  1111 1111  1111 1100
补码右移2位为:0011 1111  1111 1111  1111 1111  1111 1111,即2^30-1,值为1073741823
System.out.println(y>>>2);//1073741823

( ^ )亦或运算 ,针对二进制,相同的为0,不同的为1

public static void main(String[] args) {
    System.out.println("2^3运算的结果是 :"+(2^3));
    //打印的结果是:   2^3运算的结果是 :1
}

分析:
2 =======>0010
3 =======>0011
2^3就为0001,结果就是1

(&)与运算,针对二进制,只要有一个为0,就为0

public static void main(String[] args) {
         System.out.println("2&3运算的结果是 :"+(2&3));
         //打印的结果是:   2&3运算的结果是 :2
     }

分析:
2 =======>0010
3 =======>0011
2^3就为0010,结果就是2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值