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型,跟预期结果一致