天天看點

C++20 bit 位操作函數

C++20 bit 位操作函數

    • 01 bit
    • 02 std::lerp 和 std::midpoint

01 bit

C++20 增加了

<bit>

頭檔案,

<bit>

提供數個通路、操作及處理單獨位和位序列的函數模闆。1

方法 作用
bit_cast 将一個類型的對象表示重解釋為另一類型的對象表示
has_single_bit 檢查一個數是否為二的整數次幂
bit_ceil 尋找不小于給定值的最小的二的整數次幂
bit_floor 尋找不大于給定值的最大的二的整數次幂
bit_width 尋找表示給定值所需的最小位數
rotl 計算逐位左旋轉的結果
rotr 計算逐位右旋轉的結果
countl_zero 從最高位起計量連續的 0 位的數量
countl_one 從最高位起計量連續的 1 位的數量
countr_zero 從最低位起計量連續的 0 位的數量
countr_one 從最低位起計量連續的 1 位的數量
popcount 計量無符号整數中為 1 的位的數量
endian 訓示标量類型的端序(枚舉)

<bit>

标準頭檔案描述。2

namespace std {
    // bit_cast
    template<class To, class From>
    constexpr To bit_cast(const From& from) noexcept;
 
    // 2 的整數次幂
    template <class T>
    constexpr bool has_single_bit(T x) noexcept;
    template <class T>
    constexpr T bit_ceil(T x);
    template <class T>
    constexpr T bit_floor(T x) noexcept;
    template <class T>
    constexpr T bit_width(T x) noexcept;
 
    // 旋轉
    template<class T>
    [[nodiscard]] constexpr T rotl(T x, int s) noexcept;
    template<class T>
    [[nodiscard]] constexpr T rotr(T x, int s) noexcept;
 
    // 計數
    template<class T>
    constexpr int countl_zero(T x) noexcept;
    template<class T>
    constexpr int countl_one(T x) noexcept;
    template<class T>
    constexpr int countr_zero(T x) noexcept;
    template<class T>
    constexpr int countr_one(T x) noexcept;
    template<class T>
    constexpr int popcount(T x) noexcept;
 
    // 端序
    enum class endian {
        little = /*由實作定義*/,
        big    = /*由實作定義*/,
        native = /*由實作定義*/
    };
}
           

02 std::lerp 和 std::midpoint

// 計算 `a + t(b-a)` ,即 a 與 b 間參數為 t 的線性内插(或為外插,當 t 落在範圍 [0,1] 外時)。
// 定義于頭檔案 <cmath>
constexpr float       lerp( float a, float b, float t ) noexcept;
constexpr double      lerp( double a, double b, double t ) noexcept;
constexpr long double lerp( long double a, long double b, long double t ) noexcept;

// 計算整數、浮點或指針 a 與 b 的中點。
std::cout << std::midpoint(3, 6) << std::endl;
           

https://github.com/5455945/cpp_demo/blob/master/C%2B%2B20/bit/bit.cpp

  1. 數值庫 ↩︎
  2. 标準庫頭檔案

    <bit>

    ↩︎

繼續閱讀