命名空间
变体
操作

std::bitset<N>::set

来自 cppreference.cn
< cpp‎ | 工具库‎ | bitset
 
 
 
 
bitset& set();
(1) (C++11 起无异常抛出)
(C++23 起为 constexpr)
bitset& set( std::size_t pos, bool value = true );
(2) (C++23 起为 constexpr)

将所有位设为 true ,或将某一位设为指定值。

1) 将所有位设为 true
2) 将位置 pos 处的位设为值 value

目录

[编辑] 参数

pos - 要设置的位的起始位置(从 0 开始计数,即从最低有效位到最高有效位)
value - 要将位设置成的值

[编辑] 返回值

*this

[编辑] 异常

2)pos 不对应于有效的位位置,则抛出 std::out_of_range

[编辑] 示例

#include <bitset>
#include <cstddef>
#include <iostream>
 
int main()
{
    std::bitset<8> b;
    std::cout << b << '\n';
    std::cout << b.set() << '\n';
    std::cout << b.reset() << '\n';
 
    for (std::size_t i = 1; i < b.size(); i += 2)
        b.set(i);
 
    std::cout << b << '\n';
}

输出

00000000
11111111
00000000
10101010

[编辑] 缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
LWG 186 C++98 value 的类型是 int 更正为 bool
LWG 2250 C++98 如果 pos
对应于有效的位位置
在这种情况下总是抛出
异常

[编辑] 参阅

将位设置为 false
(public member function) [编辑]
切换位的值
(public member function) [编辑]