c++++的bitset类模板适合处理位操作,支持初始化、设置、查询等方法。1. 初始化可通过字符串、整数或默认构造;2. 支持set、reset、flip修改位状态;3. 提供test、any、none、count等查询方法;4. 支持位运算符如&、|、^、>;5. 转换可用to_ulong和to_string方法。使用时需注意索引顺序及长度限制。

C++的bitset是一个非常实用的类模板,特别适合处理位操作。它封装了对二进制位的操作,使得我们不需要手动写位运算也能轻松处理位集合问题。如果你经常需要做状态标记、权限控制或者简单的位压缩存储,bitset会是你的得力助手。

下面我们就来看看在实际使用中,bitset有哪些常用方法和技巧。
初始化 bitset 的几种方式
bitset的大小是固定的,在编译时就要确定下来。你可以通过字符串、整数或者默认构造来初始化一个bitset对象。
立即学习“C++免费学习笔记(深入)”;

-
用字符串初始化:
std::bitset<8> b1("10101010");这种方式直观,适合从外部输入读取的情况。
-
用整数初始化:
std::bitset<8> b2(42); // 二进制为 00101010
这个时候要注意高位补零的问题。
-
默认初始化:
std::bitset<8> b3;
所有位都初始化为0。
字符串初始化的时候,默认是从右到左对应低位到高位,也就是说字符串最左边的是最高位。
设置、重置与翻转位
这三个操作是最常见的修改位集合的方式:
-
set(pos):将指定位置设为1 -
reset(pos):将指定位置设为0 -
flip(pos):将指定位翻转(0变1,1变0)
如果不传参数,则操作整个bitset。比如b.set()会把所有位设为1。
举个例子:
std::bitset<8> b("00000000");
b.set(3); // 第四位变成1
b.reset(0); // 最低位清0(本来就是0)
b.flip(3); // 第四位再翻回来这些方法简单直接,但要记得索引是从右边开始算的,也就是第0位是最低位。
查询与转换操作
有时候你只是想看看某个位的状态,或者把bitset的结果转换成其他形式:
-
test(pos):检查某一位是否为1 -
any():是否有任意一位为1 -
none():是否全部为0 -
count():统计有多少位是1 -
to_ulong()或to_string():分别转换成整数或字符串
例如:
std::bitset<8> b("10101010");
bool isSet = b.test(0); // false
size_t count = b.count(); // 4
unsigned long value = b.to_ulong(); // 170需要注意的是,如果bitset的长度超过目标类型所能容纳的位数(比如用64位的bitset调用to_ulong()),结果可能溢出。
基本运算符的使用
bitset支持常见的位运算符,比如&(与)、|(或)、^(异或)、~(非)、 和 >> 移位操作。
举个例子:
std::bitset<8> a("1100");
std::bitset<8> b("1010");
std::bitset<8> c = a & b; // 1000
std::bitset<8> d = a << 2; // 110000这类操作非常适合用于组合状态标志或者做一些快速的逻辑判断。
基本上就这些。bitset虽然功能不算复杂,但在处理位级操作时确实方便不少,而且不容易出错。只要注意索引顺序和长度限制,用起来还是很顺手的。









