命名空间
变体
操作

std::bitset<N>::bitset

来自 cppreference.cn
< cpp‎ | utility‎ | bitset
 
 
 
 
bitset();
(1) (noexcept since C++11) (自 C++11 起为 noexcept)
(constexpr since C++11) (自 C++11 起为 constexpr)
(2)
bitset( unsigned long val );
(until C++11) (直到 C++11)
constexpr bitset( unsigned long long val ) noexcept;
(since C++11) (自 C++11 起)
template< class CharT, class Traits, class Alloc >

explicit bitset
    ( const std::basic_string<CharT, Traits, Alloc>& str,
      typename std::basic_string
                   <CharT, Traits, Alloc>::size_type pos = 0,
      typename std::basic_string<CharT, Traits, Alloc>::size_type
          n = std::basic_string<CharT, Traits, Alloc>::npos,

      CharT zero = CharT('0'), CharT one = CharT('1') );
(3) (constexpr since C++23) (自 C++23 起为 constexpr)
template< class CharT, class Traits >

constexpr explicit bitset
    ( std::basic_string_view<CharT, Traits> str,
      std::size_t pos = 0, std::size_t n = std::size_t(-1),

      CharT zero = CharT('0'), CharT one = CharT('1') );
(4) (since C++26) (自 C++26 起)
template< class CharT >

explicit bitset( const CharT* str, std::size_t n = std::size_t(-1),

                 CharT zero = CharT('0'), CharT one = CharT('1') );
(5) (since C++11) (自 C++11 起)
(constexpr since C++23) (自 C++23 起为 constexpr)

从多个可选数据源构造新的 bitset

1) 默认构造函数。构造一个所有位都设置为零的 bitset。
2) 从无符号整数 val 构造一个 bitset。
给定 unsigned long(直到 C++11)unsigned long long(自 C++11 起)值表示中的位数作为 S
  • 前(最右边,最低有效位)std::min(S, N) 位位置使用 val 的相应位值初始化。
  • 如果 S 小于 N,则剩余的位位置初始化为零。
3) 使用 str 中的字符构造一个 bitset。可以提供可选的起始位置 pos 和长度 n,以及表示设置位 (one) 和未设置位 (zero) 的备用值的字符。Traits::eq() 用于比较字符值。
初始化字符串的有效长度为 std::min(n, str.size() - pos)
4) 类似于 (3),但使用 std::basic_string_view 而不是 std::basic_string
5) 类似于 (3),但使用 const CharT* 而不是 std::basic_string

等效于 bitset(n == std::basic_string<CharT>::npos
          ? std::basic_string<CharT>(str)
          :std::basic_string<CharT>(str, n), 0, n, zero, one)

(until C++26) (直到 C++26)

等效于 bitset(n == std::basic_string_view<CharT>::npos
          ? std::basic_string_view<CharT>(str)
          :std::basic_string_view<CharT>(str, n), 0, n, zero, one)

(since C++26) (自 C++26 起)

目录

[编辑] 参数

val - 用于初始化 bitset 的数字
str - 用于初始化 bitset 的字符串
pos - str 的起始偏移量
n - 要从 str 使用的字符数
zero - str 中未设置位的备用字符
one - str 中设置位的备用字符

[编辑] 异常

3,4) 如果 pos > str.size(),则为 std::out_of_range;如果任何字符不是 onezero,则为 std::invalid_argument
5) 如果任何字符不是 onezero,则为 std::invalid_argument

[编辑] 注意

特性测试 Std 特性
__cpp_lib_constexpr_bitset 202207L (C++23) 更 constexpr 的 std::bitset,重载 (3,5)
__cpp_lib_bitset 202306L (C++26) std::bitsetstd::string_view 的接口,(4)

[编辑] 示例

#include <bitset>
#include <climits>
#include <iostream>
#include <string>
 
int main()
{
    // empty constructor (1)
    std::bitset<8> b1; // [0,0,0,0,0,0,0,0]
 
    // unsigned long long constructor (2)
    std::bitset<8> b2(42);          // [0,0,1,0,1,0,1,0]
    std::bitset<70> bl(ULLONG_MAX); // [0,0,0,0,0,0,1,1,1,...,1,1,1] in C++11
    std::bitset<8> bs(0xfff0);      // [1,1,1,1,0,0,0,0]
 
    // string constructor (3)
    std::string bit_string = "110010";
    std::bitset<8> b3(bit_string);       // [0,0,1,1,0,0,1,0]
    std::bitset<8> b4(bit_string, 2);    // [0,0,0,0,0,0,1,0]
    std::bitset<8> b5(bit_string, 2, 3); // [0,0,0,0,0,0,0,1]
 
    // string constructor using custom zero/one digits (3)
    std::string alpha_bit_string = "aBaaBBaB";
    std::bitset<8> b6(alpha_bit_string, 0, alpha_bit_string.size(),
                      'a', 'B');         // [0,1,0,0,1,1,0,1]
 
    // char* constructor using custom digits (5)
    std::bitset<8> b7("XXXXYYYY", 8, 'X', 'Y'); // [0,0,0,0,1,1,1,1]
 
    std::cout <<   "b1: " << b1 << "\nb2: " << b2 << "\nbl: " << bl
              << "\nbs: " << bs << "\nb3: " << b3 << "\nb4: " << b4
              << "\nb5: " << b5 << "\nb6: " << b6 << "\nb7: " << b7 << '\n';
}

可能的输出

b1: 00000000
b2: 00101010
bl: 0000001111111111111111111111111111111111111111111111111111111111111111
bs: 11110000
b3: 00110010
b4: 00000010
b5: 00000001
b6: 01001101
b7: 00001111

[编辑] 缺陷报告

以下行为变更缺陷报告被追溯应用于先前发布的 C++ 标准。

DR 应用于 已发布行为 正确行为
LWG 396 C++98 重载 (3) 的 zero 和 one 字符的值
01(它们与 '0''1' 不对应)
添加了参数以提供
这些字符的值
LWG 457 C++98 SCHAR_BIT * sizeof(unsigned long)
对于重载 (2),但 unsigned long 不是
保证使用其所有位来表示其值
考虑数字
值表示的位数
而是表示
LWG 2250 C++98 如果 pos > str.size()true,则行为未定义 在这种情况下始终抛出
异常

[编辑] 参见

将位设置为 true 或给定值
(public member function) [编辑]
将位设置为 false
(public member function) [编辑]