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
- 數值庫 ↩︎
- 标準庫頭檔案
↩︎<bit>