在Thinking in Java第三章中的一段话:
移位运算符面向的运算对象也是
二进制的“位”。 可单独用它们处理整数类型(主类型的一种)。左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补0)。 “有符号”右移位运算符(>>)则将运算符左边的运算对象向右移动运算符右侧指定的位数。“有符号”右移位运算符使用了“符号扩展”:若值为正,则在高位插入0;若值为负,则在高位插入1。Java也添加了一种“无符号”右移位运算符(>>>),它使用了“零扩展”:无论正负,都在高位插入0。这一运算符是C或C++没有的。
若对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。只有右侧的5个低位才会用到。这样可防止我们在一个int数里移动不切实际的位数。若对一个long值进行处理,最后得到的结果也 是long。此时只会用到右侧的6个低位,防止移动超过long值里现成的位数。但在进行“无符号”右移位时,也可能遇到一个问题。若对byte或 short值进行右移位运算,得到的可能不是正确的结果(Java 1.0和Java 1.1特别突出)。它们会自动转换成int类型,并进行右移位。但“零扩展”不会发生,所以在那些情况下会得到-1的结果。
其中的5个低位,和后面的6个低位,具体是什么意思?
------解决方案--------------------
package csdn;
public class OperateTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
char c1 = 0x0010;//0000 0000 0001 0000
char c2 = 0x0001;//0000 0000 0000 0001 => 1
char c3 = 0x0011;//0000 0000 0001 0001 =>17
char c4 = 0x0021;//0000 0000 0010 0001 =>33
System.out.println("移位前:" + Integer.toBinaryString(c1));
System.out.println("左移c2位:"+ Integer.toBinaryString(c1 << c2));
System.out.println("左移c3位:"+ Integer.toBinaryString(c1 << c3));
System.out.println("左移c4位:"+ Integer.toBinaryString(c1 << c4));
/**结果:
* 移位前:10000
* 左移c2位:100000
* 左移c3位:1000000000000000000000
* 左移c4位:100000
*
* 总结:
* 说明高于5位的数没起作用,也就是只用了前5位来表示可移动的范围,
* 第6位能表示到2^6=64位宽度,超出int的32位范围了;
* 再说第二个结果,输出时长度远超出了char的长度,说明移位的时候就把char延长了,
* 参考书上,那么应该是把char转成int再移位的。
*
* 以上只是个人想法,具体自己测试吧,
* byte short自己写写试试吧,这两个应该都是转成int的。:)
*/
}
}