关于(二进制)位移运算:带符号右移位;带符号左移位;无符号右移位

>> 带符号右移位

分析:num>> n

(1)相当于num(num的二进制)向右移动n位。

(2)正数移位:右边(低位)移出部分,直接舍弃,左边(高位)移入部分全部补0。(正数的符号为是0)

         负数移位:右边(低位)移出部分,直接舍弃,左边(高位)移入部分全部补1。(负数的符号为是1)

(3)移位结果:相当于num除以2的n次方后,向下取整。正负数通用;

            正数移位(2的n次方大于num)大于本身时,结果为0;移位足够大时结果为本身(暂未深入研究)

            负数移位(2的n次方大于num的绝对值)大于本身绝对值时,结果为-1;移位足够大时结果为本身(暂未深入研究)

            num>>0位后,结果为其本身;

            0>>n后仍然为0。

 案例:

System.out.println(8>>1);  结果:4        System.out.println(-8>>1);  结果:-4

System.out.println(8>>2);  结果:2        System.out.println(-8>>2);  结果:-2

System.out.println(7>>1);  结果:3        System.out.println(-7>>1);  结果:-4

System.out.println(7>>2);  结果:1        System.out.println(-7>>2);  结果:-2

System.out.println(8>>0);  结果:8        System.out.println(-8>>0);  结果:-8

System.out.println(8>>100);  结果:0        System.out.println(-8>>100);  结果:-1

System.out.println(8>>1000000);  结果:8        System.out.println(-8>>10000000);  结果:-8

<< 带符号左移位

分析:num<< n

(1)相当于num(num的二进制)向左移动n位。

(2)左边(高位)移出部分,直接舍弃;右边(低位)移入部分全部补0。

(3)移位结果:相当于num乘以2的n次方,移位足够大时,结果为其本身(暂未深入研究)。正负数通用;

                          num>>0位后,结果为其本身;

                          0<<n后仍然为0。

 案例:

System.out.println(8<<1);  结果:16        System.out.println(-8<<1);  结果:-16

System.out.println(8<<2);  结果:32        System.out.println(-8<<2);  结果:-32

System.out.println(7<<1);  结果:14        System.out.println(-7<<1);  结果:-14

System.out.println(7<<2);  结果:28        System.out.println(-7<<2);  结果:-28

System.out.println(8<<0);  结果:8        System.out.println(-8<<0);  结果:-8

System.out.println(8<<1000000);  结果:8        System.out.println(-8<<1000000);  结果:-8

>>> 无符号右移位

分析:num>>>n

(1)对于正数和0,无符号右移位>>>和带符号右移位>>,结果是一样的。

(2)负数移位:右边(低位)移出部分,直接舍弃,左边(高位)移入部分全部补0。(符号为由1变成0,所以负数变正数)  

(3)移位结果:正数移位相当于num除以2的n次方后,向下取整;当移位(2的n次方大于num)大于本身时,结果为0;

                          负数移位需要根据以后结果进行计算;

                          当移位(2的n次方大于num)远大于本身时,结果为num本身,正负数通用。

                          num>>>0位后,结果为其本身;

                          0>>>n后仍然为0。

 案例:

System.out.println(8>>>1);  结果:4        System.out.println(-8>>1);  结果:2147483644

System.out.println(8>>>2);  结果:2        System.out.println(-8>>2);  结果:1073741822

System.out.println(7>>>1);  结果:3        System.out.println(-7>>1);  结果:2147483644

System.out.println(7>>>2);  结果:1        System.out.println(-7>>2);  结果:1073741822

System.out.println(8>>>0);  结果:8        System.out.println(-8>>>0);  结果:-8

System.out.println(8>>>100);  结果:0    System.out.println(-8>>>100);  结果:268435455

System.out.println(8>>>1000000);  结果:8        System.out.println(-8>>>10000000);  结果:-8             

猜你喜欢

转载自blog.csdn.net/weixin_42315600/article/details/80567944