2008年(3500)
分类:
2008-05-04 23:11:25
试看:
1.) byte a = 27;// 转换成int为 00000000000000000000000000011011
byte b = -1;转换成int为 11111111111111111111111111111111
int g = a >> 1;// 有符号右移1位,左侧缺的位以符号位补齐,正数就是0, "00000000000000000000000000001101" = 13
int f = b>> 1; // 有符号右移1位,左侧缺的位以符号位补齐,负数就是1, “11111111111111111111111111111111”= -1
故此时打印出来,g=13,gf=-1。
g = a >>> 1;// 无符号右移1位,左侧缺的位以0补齐, "00000000000000000000000000001101" = 13
f = b>>> 1; // 无符号右移1位,左侧缺的位以0补齐, “01111111111111111111111111111111”= 2147483647
故此时打印出来,g=13,gf=2147483647。
f = b<< 1; // 无符号左移1位,右侧缺的位以0补齐, “10000000000000000000000000000010“= -2
故此时打印出来,f= -2
在Thinking in Java第三章中的一段话:
移位运算符面向的运算对象也是
若对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。只有右侧的5个低位才会用到。这样可防止我们在一个int数里移动不切实际的位数。若对一个long值进行处理,最后得到的