左シフト演算子 (<<
)は、1つ目のオペランドを指定されたビット数だけ左にずらします。左にずらしてあふれたビットは廃棄されます。0のビットが右からずれて入ります。
このデモのソースファイルは GitHub リポジトリに格納されています。デモプロジェクトに協力していただける場合は、 https://github.com/mdn/interactive-examples をクローンしてプルリクエストを送信してください。
構文
a << b
解説
この演算子は、1つ目のオペランドを指定されたビット数だけ左にずらします。左にずらしてあふれたビットは廃棄されます。0のビットが右からずれて入ります。
例えば 9 << 2
は 36 になります。
. 9 (10進数): 00000000000000000000000000001001 (2進数)
--------------------------------
9 << 2 (10進数): 00000000000000000000000000100100 (2進数) = 36 (10進数)
任意の数 x
を y
ビット分だけ左にビット単位にずらすと、 x * 2 ** y
になります。
ですから、例えば 9 << 3
は 9 * (2 ** 3) = 9 * (8) = 72
になります。
例
左シフトの使用
9 << 3; // 72
// 9 * (2 ** 3) = 9 * (8) = 72
仕様書
ブラウザーの互換性
BCD tables only load in the browser
このページの互換性一覧表は構造化データから生成されています。データに協力していただけるのであれば、 https://github.com/mdn/browser-compat-data をチェックアウトしてプルリクエストを送信してください。