Java 中的位运算右移运算符\n
Java 支持两种类型的右移运算符。>> 运算符是有符号右移运算符,而 >>> 是无符号右移运算符。左操作数的值按照右操作数指定的位数右移。
有符号右移运算符
有符号右移运算符 '>>' 使用符号位填充尾部位置。例如,如果数字为正,则使用 0 填充尾部位置;如果数字为负,则使用 1 填充尾部位置。
假设 a = 60,b = -60;现在以二进制格式,它们如下 −
a = 0000 0000 0000 0000 0000 0000 0011 1100 b = 1111 1111 1111 1111 1111 1111 1100 0100
在 Java 中,负数存储为 2 的补码。
Thus a >> 1 = 0000 0000 0000 0000 0000 0000 0001 1110 And b >> 1 = 1111 1111 1111 1111 1111 1111 1110 0010
无符号右移运算符
无符号右移运算符 '>>>' 不使用符号位填充尾部位置。它总是使用 0 填充尾部位置。
Thus a >>> 1 = 0000 0000 0000 0000 0000 0000 0001 1110 And b >>> 1 = 0111 1111 1111 1111 1111 1111 1110 0010
示例
public class Tester { public static void main(String[] args) { int a = 60; int b = -60; int c = 0; System.out.println("60 = " + Integer.toBinaryString(a)); System.out.println("-60 = " + Integer.toBinaryString(b)); //signed shift c = a >> 1; System.out.println("60 >> 1 = " + Integer.toBinaryString(c)); //unsigned shift c = a >>> 1; System.out.println("60 >>> 1 = " + Integer.toBinaryString(c) ); c = b >> 1; System.out.println("-60 >> 1 = " + Integer.toBinaryString(c) ); c = b >>> 1; System.out.println("-60 >>> 1 = " + Integer.toBinaryString(c)); } }
输出
60 = 111100 -60 = 11111111111111111111111111000100 60 >> 1 = 11110 60 >>> 1 = 11110 -60 >> 1 = 11111111111111111111111111100010 -60 >>> 1 = 1111111111111111111111111100010
广告