本文目录一览:
Java中,位运算符>>,右移时左边何时补0,何时补1
在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的结果。
java逻辑右移
2二进制表示为10,逻辑右移两位即为0。
逻辑右移(),无论什么时候都在左填0。而算术右移()则在左填符号位,符号位若为0则与逻辑右移结果一致,符号位为1则不一致。
java 无符号右移
首先纠正一个错误哈..
是带符号右移
才是无符号右移..
带符号右移就是将那个数转为2进制然后在前面补0或1
如果是正数就补0
负数补1
例如11
2,则是将数字11右移2位
计算过程:
11的二进制形式为:0000
0000
0000
0000
0000
0000
0000
1011,然后把低位的最后两个数字移出,因为该数字是正数,所以在高位补零。则得到的最终结果是0000
0000
0000
0000
0000
0000
0000
0010。转换为十进制是2。
其他的
到网上一搜就有了。。
无符号右移与带符号右移的区别就是
无符号始终补0
Java 中 算术右移和逻辑右移有什么区别
逻辑右移就是不用考虑最高位的符号位,只需要在移动之后的空位补0就行了,例如
初始数据:
1111
1111
右移一位:
0111
1111
最高位补0
算术右移则是要考虑符号位,如果最高位为1、则移动后在最高位补1、若最高位不为1,则移动后在最高位补0,例如
初始数据,最高位为1:
1111
1001
右移一位
1111
1100
初始数据,最高位不为1:
0111
1001
右移一位
0011
1100
关于Java的算术右移运算符
你说的右移应该是整数除法里面提到的吧。
整数除法总是zero-round,即商总是向靠近0的数方向进行舍入。
因为要向0靠近,所以负数在除2的幂之前会先加上一个偏移量2的k次方减1(2k-1,k为右移的位数)以修正
假设8位有符号表示:
则-5的补码为 1111 1011
右移一位: 1111 1101
上面的结果是-3的补码,和实际不符(-5/2 = -2)
加上修正值: 1111 1011 + 2的一次方减1 = 1111 1011 + 1 = 1111 1100
然后再右移一位:1111 1110 = -2的补码!