Namespaces
Variants

std:: rotl

From cppreference.net
Utilities library
ヘッダーで定義 <bit>
template < class T >
constexpr T rotl ( T x, int s ) noexcept ;
(C++20以降)

x の値を s ポジション分だけビット単位で左回転した結果を計算します。この操作は左 巡回シフト としても知られています。

形式的には、 N std:: numeric_limits < T > :: digits とし、 r s % N とする。

  • r 0 の場合、 x を返す;
  • r が正の場合、 ( x << r ) | ( x >> ( N - r ) ) を返す;
  • r が負の場合、 std:: rotr ( x, - r ) を返す。

このオーバーロードは、 T が符号なし整数型(つまり、 unsigned char unsigned short unsigned int unsigned long unsigned long long 、または拡張符号なし整数型)である場合にのみ、オーバーロード解決に参加します。

目次

パラメータ

x - 符号なし整数型の値
s - シフトするビット数

戻り値

x s ビット位置だけ左回転した結果。

注記

機能テスト マクロ 標準 機能
__cpp_lib_bitops 201907L (C++20) ビット操作

#include <bit>
#include <bitset>
#include <cstdint>
#include <iostream>
int main()
{
    using bin = std::bitset<8>;
    const std::uint8_t x{0b00011101};
    std::cout << bin(x) << " <- x\n";
    for (const int s : {0, 1, 4, 9, -1})
        std::cout << bin(std::rotl(x, s)) << " <- rotl(x, " << s << ")\n";
}

出力:

00011101 <- x
00011101 <- rotl(x, 0)
00111010 <- rotl(x, 1)
11010001 <- rotl(x, 4)
00111010 <- rotl(x, 9)
10001110 <- rotl(x, -1)

関連項目

(C++20)
ビット単位の右回転の結果を計算する
(関数テンプレート)
バイナリ左シフトと右シフトを実行する
( std::bitset<N> の公開メンバ関数)