std::bitset<N>:: bitset
|
bitset
(
)
;
|
(1) |
(noexcept начиная с C++11)
(constexpr начиная с C++11) |
| (2) | ||
|
bitset
(
unsigned
long
val
)
;
|
(до C++11) | |
|
constexpr
bitset
(
unsigned
long
long
val
)
noexcept
;
|
(начиная с C++11) | |
|
template
<
class
CharT,
class
Traits,
class
Alloc
>
explicit
bitset
|
(3) | (константное выражение начиная с C++23) |
|
template
<
class
CharT,
class
Traits
>
constexpr
explicit
bitset
|
(4) | (начиная с C++26) |
|
template
<
class
CharT
>
explicit
bitset
(
const
CharT
*
str,
std::
size_t
n
=
std::
size_t
(
-
1
)
,
|
(5) |
(начиная с C++11)
(константное выражение начиная с C++23) |
Создает новый битовый набор из одного из нескольких возможных источников данных:
- Первые (крайние правые, младшие) std:: min ( S, N ) битовые позиции инициализируются соответствующими битовыми значениями из val .
- Если S меньше N , оставшиеся битовые позиции инициализируются нулями.
Traits::eq()
используется для сравнения значений символов.
|
Эквивалентно
bitset
(
n
==
std::
basic_string
<
CharT
>
::
npos
|
(до C++26) |
|
Эквивалентно
bitset
(
n
==
std::
basic_string_view
<
CharT
>
::
npos
|
(начиная с C++26) |
Содержание |
Параметры
| val | - | число, используемое для инициализации битового набора |
| str | - | строка, используемая для инициализации битового набора |
| pos | - | начальное смещение в str |
| n | - | количество символов для использования из str |
| zero | - | альтернативный символ для сброшенных битов в str |
| one | - | альтернативный символ для установленных битов в str |
Исключения
Примечания
| Макрос тестирования возможностей | Значение | Стандарт | Возможность |
|---|---|---|---|
__cpp_lib_constexpr_bitset
|
202207L
|
(C++23) |
Более константное выражение
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() { // конструктор по умолчанию (1) std::bitset<8> b1; // [0,0,0,0,0,0,0,0] // конструктор с unsigned long long (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] в C++11 std::bitset<8> bs(0xfff0); // [1,1,1,1,0,0,0,0] // строковый конструктор (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] // строковый конструктор с пользовательскими символами (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* и пользовательскими символами (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 | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 396 | C++98 |
значения символов нуля и единицы для перегрузки
(3)
были 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
или заданное значение
(публичная функция-член) |
|
|
устанавливает биты в
false
(публичная функция-член) |