日期:2014-05-20  浏览次数:20966 次

java 运算符左移<<与右移>>是否可逆
比如111右移两位是27,然后用27左移两位是108,明白左移是乘以2的n次方,右移是除以2的n次方,请问我如何让27左移两位本来是多少就是多少呢,如111(110,109)右移两位,在左移回来的时候还是111而不是108

public class data17 {
public static void main(String[] args) {
int a=110;
int c=-4;
int b=2;
int d=2;
System.out.println("a 的移位结果:"+(a>>b));
System.out.println("c 的移位结果:"+(c<<d));
}
}

------解决方案--------------------
当然不可逆。

除非你将你的数换算成2进制后,右边可移位的0位数够。

比如:4(十进制)=100(2进制),右移两位再左移两位还是原来的值

Java code

System.out.println((4>>2));
System.out.println((4>>2<<2));

------解决方案--------------------
不可逆的~~!左移是低位补0,右移高位根据数据的符号进行补:负号补1,正数补0!
------解决方案--------------------
Java code
public class test {

    public static void main(String[] args) {
        p(4>>2);
        p(5>>2);
    }

    private static void p( Object o ) {
        System.out.println(o);
    }

}

------解决方案--------------------
LZ想循环左右移。。java中,不直接支持