比如111右移两位是27,然后用27左移两位是108,明白左移是乘以2的n次方,右移是除以2的n次方,请问我如何让27左移两位本来是多少就是多少呢,如111(110,109)右移两位,在左移回来的时候还是111而不是108public 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));
}
}

解决方案 »

  1.   

    当然不可逆。除非你将你的数换算成2进制后,右边可移位的0位数够。比如:4(十进制)=100(2进制),右移两位再左移两位还是原来的值
    System.out.println((4>>2));
    System.out.println((4>>2<<2));
      

  2.   

    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);
    }}这2个输出都是1的,呵呵
    4是100,5是101,位移后5的1会移米了
      

  3.   

    LZ想循环左右移。。java中,不直接支持
      

  4.   

    Integer.rotateLeft(i, distance)
    Integer.rotateRight(i, distance)