java中有以下移位运算规则:
"<<":带符号左移,向左移动n位,向低位添加0,如下图所示
public class Test {
public static void main(String[] args) {
int a = -1;
System.out.println(Integer.toBinaryString(a));
a <<= 2;//a左移两位
System.out.println(Integer.toBinaryString(a));
}
}
/*
* 结果如下:
* 11111111111111111111111111111111(-1的补码)
* 11111111111111111111111111111100
* */
"a>>n":带符号右移,向右移动n位。如果a为正数,向高位添加0;如果a为负数,向高位添加1。如下图所示
import java.awt.print.Printable;
import javax.xml.crypto.dsig.SignedInfo;
public class Test {
public static void main(String[] args) {
int a = -1;
System.out.println(Integer.toBinaryString(a));
a >>= 2;//a右移两位
System.out.println(Integer.toBinaryString(a));
int b = 1;
System.out.println(Integer.toBinaryString(b));
b >>= 2;//a右移两位
System.out.println(Integer.toBinaryString(b));
}
}
/*
* 结果如下:
* 11111111111111111111111111111111
* 11111111111111111111111111111111
* 1
* 0
* */
"a>>>n":无符号右移,无论a为正负,都在高位添加0,如下所示
import java.awt.print.Printable;
import javax.xml.crypto.dsig.SignedInfo;
public class Test {
public static void main(String[] args) {
int a = -1;
System.out.println(Integer.toBinaryString(a));
a >>>= 2;//a右移两位
System.out.println(Integer.toBinaryString(a));
int b = 1;
System.out.println(Integer.toBinaryString(b));
b >>>= 2;//a右移两位
System.out.println(Integer.toBinaryString(b));
}
}
/*
* 结果如下:
* 11111111111111111111111111111111
* 111111111111111111111111111111
* 1
* 0
* */
另外特别要注意:
char,byte,short型数据转换时,会先被转换为int型在进行移位,结果仍然为int型。所以如果用short,byte进行移位,得不到预期的结果,如下所示
public class Test {
public static void main(String[] args) {
byte a = -1;
System.out.println(Integer.toBinaryString(a));
a >>= 2;//a右移两位
System.out.println(Integer.toBinaryString(a));
short b = -1;
System.out.println(Integer.toBinaryString(b));
b >>>= 2;//a右移两位
System.out.println(Integer.toBinaryString(b));
}
}
/*
* 结果如下:(都是按照int型处理)
* 11111111111111111111111111111111
* 11111111111111111111111111111111
* 11111111111111111111111111111111
* 11111111111111111111111111111111
* */
如果使用long,结果则为long型,跟预期结果一致