[转]java中char,byte,short的位移操作
[转]java中char,byte,short的移位操作int i 1245String s Integer.toBinaryString(i)int y1 i2
[转]java中char,byte,short的移位操作
int i = 1245;String s = Integer.toBinaryString(i);int y1 = i>>2;String s1 = Integer.toBinaryString(y1);int y2 = i>>34;String s2 = Integer.toBinaryString(y2);System.out.println(i + "->" + s + " " + y1 + "->" + s1 + " " + y2 + "->" + s2);语句“int y2 = i>>34;”的执行过程是:先把i化成二进制数:10011011101
?执行结果:
1245->10011011101 311->100110111 311->100110111
?
执行语句 i>> 34?? 对i右移34位时,先把34化成二进制:100010,对该二进制数取右边5位,即00010,化成十进制数为2,所以实际上是对i右移两位。现在,结果是:100110111
?
?
long型数据移位时一样的道理,long型一共64位,如果移动的位数超过64(2^8)就没有意义了,所以在移位前判断移动的位数是否大于64,如果大于了64则取该位数的低8位(除以64得到的余数),再移位,否则直接移位。
移位运算符和按位运算符一样,同属于位运算符,因此移位运算符的位指的也是二进制位。它包括以下几种:
左移位(<<):将操作符左侧的操作数向左移动操作符右侧指定的位数。移动的规则是在二进制的低位补0。
- 有符号右移位(>>):将操作符左侧的操作数向右移动操作符右侧指定的位数。移动的规则是,如果被操作数的符号为正,则在二进制的高位补0;如果被操作数的符号为负,则在二进制的高位补1。
- 无符号右移位(>>>):将操作符左侧的操作数向右移动操作符右侧指定的位数。移动的规则是,无论被操作数的符号是正是负,都在二进制位的高位补0。
注意,移位运算符不存在“无符号左移位(<<<)”一说。与按位运算符一样,移位运算符可以用于byte、short、int、long等整数类型,和字符串类型char,但是不能用于浮点数类型float、double;当然,在Java5.0及以上版本中,移位运算符还可用于byte、short、int、long、char对应的包装器类。我们可以参照按位运算符的示例写一个测试程序来验证,这里就不再举例了。
与按位运算符不同的是,移位运算符不存在短路不短路的问题。
写到这里就不得不提及一个在面试题中经常被考到的题目:
- public?abstract?class?Test?{ ??
- ????public?static?void?main(String[]?args)?{ ??
- ????????System.out.println("1?<<?3?=?"?+?(1?<<?3)); ??
- ????????System.out.println("(byte)?1?<<?35?=?"?+?((byte)?1?<<?(32?+?3))); ??
- ????????System.out.println("(short)?1?<<?35?=?"?+?((short)?1?<<?(32?+?3))); ??
- ????????System.out.println("(char)?1?<<?35?=?"?+?((char)?1?<<?(32?+?3))); ??
- ????????System.out.println("1?<<?35?=?"?+?(1?<<?(32?+?3))); ??
- ????????System.out.println("1L?<<?67?=?"?+?(1L?<<?(64?+?3))); ??
- ????????//?此处需要Java5.0及以上版本支持???
- ????????System.out.println("new?Integer(1)?<<?3?=?"?+?(new?Integer(1)?<<?3)); ??
- ????????System.out.println("10000?>>?3?=?"?+?(10000?>>?3)); ??
- ????????System.out.println("10000?>>?35?=?"?+?(10000?>>?(32?+?3))); ??
- ????????System.out.println("10000L?>>>?67?=?"?+?(10000L?>>>?(64?+?3))); ??
- ????} ??
- }??
运行结果:
- 1 << 3 = 8
- (byte) 1 << 35 = 8
- (short) 1 << 35 = 8
- (char) 1 << 35 = 8
- 1 << 35 = 8
- 1L << 67 = 8
- new Integer(1) << 3 = 8
- 10000 >> 3 = 1250
- 10000 >> 35 = 1250
- 10000L >>> 67 = 1250
转自:http://blog.csdn.net/chattie/archive/2009/03/27/4029922.aspx