java中"<<",">>",">>>"等左移右移符号辨析

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值