std::bitset<N>::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 |
(3) | (constexpr since C++23) (自 C++23 起为 constexpr) |
template< class CharT, class Traits > constexpr explicit bitset |
(4) | (since C++26) (自 C++26 起) |
template< class CharT > explicit bitset( const CharT* str, std::size_t n = std::size_t(-1), |
(5) | (since C++11) (自 C++11 起) (constexpr since C++23) (自 C++23 起为 constexpr) |
从多个可选数据源构造新的 bitset
- 前(最右边,最低有效位)std::min(S, N) 位位置使用 val 的相应位值初始化。
- 如果 S 小于 N,则剩余的位位置初始化为零。
Traits::eq()
用于比较字符值。
等效于 bitset(n == std::basic_string<CharT>::npos |
(until C++26) (直到 C++26) |
等效于 bitset(n == std::basic_string_view<CharT>::npos |
(since C++26) (自 C++26 起) |
目录 |
[编辑] 参数
val | - | 用于初始化 bitset 的数字 |
str | - | 用于初始化 bitset 的字符串 |
pos | - | 到 str 的起始偏移量 |
n | - | 要从 str 使用的字符数 |
zero | - | str 中未设置位的备用字符 |
one | - | str 中设置位的备用字符 |
[编辑] 异常
[编辑] 注意
特性测试 宏 | 值 | Std | 特性 |
---|---|---|---|
__cpp_lib_constexpr_bitset |
202207L |
(C++23) | 更 constexpr 的 std::bitset ,重载 (3,5) |
__cpp_lib_bitset |
202306L |
(C++26) | std::bitset 与 std::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 字符的值 是 0 和 1(它们与 '0' 和 '1' 不对应) |
添加了参数以提供 这些字符的值 |
LWG 457 | C++98 | S 是 CHAR_BIT * sizeof(unsigned long) 对于重载 (2),但 unsigned long 不是 保证使用其所有位来表示其值 |
考虑数字 值表示的位数 而是表示 |
LWG 2250 | C++98 | 如果 pos > str.size() 为 true,则行为未定义 | 在这种情况下始终抛出 异常 |
[编辑] 参见
将位设置为 true 或给定值 (public member function) | |
将位设置为 false (public member function) |