右シフト (>>)

右シフト演算子 (>>) (ゼロ埋め右シフト) は、1つ目のオペランドを指定されたビット数だけ右にずらします。右にずらしてあふれたビットは廃棄されます。最も左のビットをコピーしながらずれて入ります。最も左のビットが以前の最も左のビットと同じになるため、符号ビット (最も左のビット) は変化しません。よって「符号維持」という名前です。

構文

a >> b

解説

この演算子は、1つ目のオペランドを指定されたビット数だけ右にずらします。右にずらしてあふれたビットは廃棄されます。最も左のビットをコピーしながらずれて入ります。最も左のビットが以前の最も左のビットと同じになるため、符号ビット (最も左のビット) は変化しません。よって「符号維持」という名前です。

例えば、 9 >>> 2 は 2 となります。

.     9 (10進数): 00000000000000000000000000001001 (2進数)
                  --------------------------------
9 >>> 2 (10進数): 00000000000000000000000000000010 (2進数) = 2 (10進数)

同様に、 -9 >> 2 は符号が保存されるため、 -3 になります。

.     -9 (10進数): 11111111111111111111111111110111 (2進数)
                   --------------------------------
-9 >> 2 (10進数):  11111111111111111111111111111101 (2進数) = -3 (10進数)

右シフトの使用

 9 >> 2; //  2
-9 >> 2; // -3

仕様書

仕様書
ECMAScript (ECMA-262)
Bitwise Shift Operators の定義

ブラウザーの互換性

Update compatibility data on GitHub
デスクトップモバイルサーバー
ChromeEdgeFirefoxInternet ExplorerOperaSafariAndroid webviewAndroid 版 ChromeAndroid 版 FirefoxAndroid 版 OperaiOSのSafariSamsung InternetNode.js
Bitwise right shift (a >> b)Chrome 完全対応 1Edge 完全対応 12Firefox 完全対応 1IE 完全対応 3Opera 完全対応 3Safari 完全対応 1WebView Android 完全対応 1Chrome Android 完全対応 18Firefox Android 完全対応 4Opera Android 完全対応 10.1Safari iOS 完全対応 1Samsung Internet Android 完全対応 1.0nodejs 完全対応 0.1.100

凡例

完全対応  
完全対応

関連情報