您的位置:

java右移,java右移一位相当于

本文目录一览:

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的补码!