JAVA基础之移位

       移位操作平时用的较少,但其实很常见。平时看一些java.lang里面的源码就会发现很多进行了移位操作。对于计算机而言,移位操作时最快的。今天简单总结下我所认识的移位操作。

       请看下面这段测试代码:

       

        //100=64+32+4
        int i = 1;
        i = ((i<<6) //i*64
        + (i<<5) //i*32
        + (i<<2)); //i*4
        System.out.println(i); //i*100
        
        int j = 1;
        j = j<<1+j+2;
        System.out.println(j);
        
        long k = 2147483648l;
        long l = k / 100;
        int r = (int)(k - ((l<<6) + (l<<5) + (l<<2)));
        System.out.println(r);
        
        int a1 = -20; //负数为补码(反码+1)int类型占4个字节,32位
        System.out.println(Integer.toBinaryString(a1));
        a1 = a1>>>20; //不考虑符号位
        System.out.println(a1);
        System.out.println(Integer.toBinaryString(a1));
        
        int a2 = -20; //负数为补码(反码+1)int类型占4个字节,32位
        System.out.println(Integer.toBinaryString(a2));
        a2 = a2>>20;
        System.out.println(a2);

        执行结果为:

        

100
16
48
11111111111111111111111111101100
4095
111111111111
11111111111111111111111111101100
-1
11111111111111111111111111111111

       可以看到,移位对于数字的操作时多么灵活,注意的是,>>与>>>,前者是考虑符号位,后者不考虑符号位。

猜你喜欢

转载自devilinjava.iteye.com/blog/2364709
今日推荐