《c++ primer》——3 标准库bitset类型

标准库bitset类型

bitset类简化处理二进制位的有序集,每个位可能包含0和1。

使用bitset类,包含相应的头文件:

#include <bitset>
using std::bitset;
bitset对象的初始化

bitset类似于vector,也是一种标准库容器,只不过它的初始化需要声明的是bitset对象的长度而不是类型。

给出的长度必须是一个常量表达式,整型字面值常量或是已用常量值初始化的const对象

	bitset<32> bit;
	int n;
	cin >> n;
	bitset<n> bit2;//error
1. 用 unsigned 值初始化 bitset 对象

unsigned long值将转化为二进制模式储存,bitset对象中的每一位将对应二进制数的每一位。

若二进制数超出bitset的长度,则二进制数的高阶位将被丢弃。如:

二进制数 1101 1011 1111 0111 1001 十进制数为 900985

bitset对象的长度为16,bitset<16> bitset对象将只存储低16位的二进制数即,1011 1111 0111 1001

若二进制数小于bitset对象的长度,则bitset对象的超出部分,将补0

2. 用string对象初始化bitset对象

string对象直接表示为位模式,string对象的字符串读入到bitset对象的顺序为从右到左,即

string s(“1100”);

bitset<16> bit(s);

那么bit[0]=0,bit[1]=0,bit[2]=1,bit[3]=1,bit其余位数为0

也可以将string对象的一部分作为bitset对象的初始值

int main()
{
	string s("1000110011");
	bitset<16> bit1(s,4,4);//从s[4]开始转换四个二进制位,从右向左开始
	cout << bit1 << endl;
	bitset<16> bit2(s, 4);//从s[4]开始转换
	cout << bit2 << endl;
	getchar();
	return 0;
}

bitset对象上的操作


分为以下几大类:

1. 测试整个bitset对象(全体)

bitset<4> bit1;// all set to 0
bool is_set = bit1.any();//整个bitset对象中如果含有1,则返回true,否则返回false
bool is_not_set = bit1.none();//整个bitset对象中如果全为0,则返回true,否则返回false
size_t bits_set = bit1.count();//return number of bits that are on
size_t 是定义在 cstddef 头文件中的,是一个与机器无关的 unsigned 类型

2. 访问bitset对象中的

bitset<32> bit;
for (int index = 0; index != 32; index += 2)
{
	bit[index] = 1;
}
for (int index = 0; index != 32; index += 2)
{
	bit.set(index);//set to 1
	bit.reset(index);//set to 0
}
if (bit.test(i))//return true if bit[i] is on
if (bit[i])//bit[i] is on

注意:在bitset对象中遍历,下标用的是int类型,因为此时我们已经知道bitset对象的长度了,并且bitset标准容器没有定义size_type类型

3.对 整个 bitset 对象进行设置

bit.reset(); //set all the bits to 0
bit.set() ;// set all the bits to 1
bit.flip();//reverses value of all bits
bit.flip[index]; //reverses value of index bit
bit[index].flip();//reverses value of index bit
4.获取 bitset 对象的值

to_ulong返回unsigned long类型的值,该值的二进制位模式与bitset对象相同,但bitset对象的长度要小于或等于unsigned long对象的长度,否则会产生异常。

int main()
{

	bitset<32> bit(0xffff);
	unsigned long data = bit.to_ulong();
	cout << data << endl;
	getchar();
	return 0;
}

 5.输出二进制位

int main()
{

	bitset<32> bit(0xffff);
	cout << "bit: " << bit << endl;
	getchar();
	return 0;
}
6.使用位操作符

bitset类支持内置的位操作符。



注意:二进制数高阶位位于左侧,低阶位位于右侧!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值