close
Пространства имён
Варианты
Действия

std::bitset<N>::operator[]

Материал из cppreference.com
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
std::bitset
Типы элементы
Функции-элементы
Доступ к элементам
Ёмкость
Модификаторы
Преобразования
Функции, не являющиеся элементами
Вспомогательные классы
(C++11)
 
<tbody> </tbody>
bool operator[]( std::size_t pos ) const;
(1) Шаблон:mark constexpr since c++11
reference operator[]( std::size_t pos );
(2) (constexpr начиная с C++23)

Получает доступ к биту в позиции pos. Первая версия возвращает значение бита, вторая версия возвращает объект типа std::bitset::reference, который позволяет изменять значение.

В отличие от test(), не генерирует исключений: поведение не определено, если pos выходит за пределы.

Параметры

pos позиция бита, который нужно вернуть

Возвращаемое значение

1) Значение запрошенного бита.
2) Объект типа std::bitset::reference, который позволяет произвести запись в запрошенный бит.

Исключения

(нет)

Пример

#include <iostream>
#include <bitset>

int main()
{
    std::bitset<8> b1{0b00101010}; // двоичный литерал для 42
    
    for (std::size_t i = 0; i < b1.size(); ++i)
        std::cout << "b1[" << i << "]: " << b1[i] << '\n';
    b1[0] = true; // изменяет первый бит через bitset::reference
    
    std::cout << "После установки бита 0, b1 содержит " << b1 << '\n';
}

Вывод:

b1[0]: 0
b1[1]: 1
b1[2]: 0
b1[3]: 1
b1[4]: 0
b1[5]: 1
b1[6]: 0
b1[7]: 0
После установки бита 0, b1 содержит 00101011

Отчёты о дефектах

Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:

Номер Применён Поведение в стандарте Корректное поведение
LWG 11 C++98 1. описание отсутствовало в стандарте C++
2. была только неконстантная перегрузка
1. добавлено описание
2. добавлена константная перегрузка
LWG 907 C++98 поведение чтения бита в pos было эквивалентно поведению test(pos),
но test() может вызывать исключения
избегает использования test()

Смотрите также

доступ к определённому биту
(public функция-элемент) [править]