Namespaces
Variants

std:: bit_width

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

x がゼロでない場合、値 x を格納するために必要なビット数を計算します。つまり、 1 + floor(log 2 (x)) です。 x がゼロの場合、ゼロを返します。

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

目次

翻訳内容: - 「Contents」→「目次」 - その他のC++関連用語(Parameters、Return value、Notes、Example、Defect reports、See also)は原文のまま保持 - HTMLタグ、属性、構造は完全に保持 - 番号付けや書式は変更なし

パラメータ

x - 符号なし整数値

戻り値

x がゼロの場合はゼロを返す。それ以外の場合、 x の底2の対数に1を加え、小数部を切り捨てた値を返す。

注記

この関数は以下と等価です: return std:: numeric_limits < T > :: digits - std:: countl_zero ( x ) ;

機能テスト マクロ 標準 機能
__cpp_lib_int_pow2 202002L (C++20) 整数の2の累乗 2 演算

#include <bit>
#include <bitset>
#include <iostream>
int main()
{
    for (unsigned x{}; x != 010; ++x)
        std::cout << "bit_width( "
                  << std::bitset<4>{x} << " ) = "
                  << std::bit_width(x) << '\n';
}

出力:

bit_width( 0000 ) = 0
bit_width( 0001 ) = 1
bit_width( 0010 ) = 2
bit_width( 0011 ) = 2
bit_width( 0100 ) = 3
bit_width( 0101 ) = 3
bit_width( 0110 ) = 3
bit_width( 0111 ) = 3

不具合報告

以下の動作変更の欠陥報告書は、以前に公開されたC++規格に対して遡及的に適用されました。

DR 適用対象 公開時の動作 正しい動作
LWG 3656 C++20 bit_width の戻り値型は関数引数の型と同じ int に変更

関連項目

最上位ビットから開始して、連続する 0 ビットの数を数える
(関数テンプレート)