HOME > シフト演算

シフト演算

シフト演算のサンプルです。

サンプルコード

シフト演算のサンプル
public class ShiftSample {

    public static void main(String args[]) {

        //シフト演算
        int a = 16;
        System.out.println(a<<1); //1ビット左シフト
        System.out.println(a<<2); //2ビット左シフト
        System.out.println(a>>1); //1ビット右シフト
        System.out.println(a>>2); //2ビット右シフト

    }

}

実行結果
C:\>java ShiftSample 32 64 8 4

シフト演算解説

シフト演算は、まず対象の数値を2進数にして考えます。
そしてその2進数のビットを左右にずらして数値を変えます。

上記サンプルで解説しますと、元となる数字16を2進数にすると、
「00010000」(=16)です。

これを1ビット左シフトさせると、全てのビットを左へ1つずつずらすことになるので、
「00100000」(=32)となります。
(ずらすことで1桁目に必要となる部分にはゼロを入れます。)

同じように元の数字を2ビット左シフトさせると、
「01000000」(=64)となります。

今度は元の数字を1ビット右シフトさせると、
「00001000」(=8)となります。

もうお分かりだと思いますが、桁落ちしない限り
左シフトさせると2倍、4倍、8倍・・・となり、
右シフトさせると1/2倍、1/4倍、1/8倍となりますので、
こういった倍数の計算は簡単にできるということです。

また、コンピュータが理解しやすい形式なので処理速度も速いです。