C++学习第二十七课:STL中的位标志(Bitset)使用指南

C++学习第二十七课:STL中的位标志(Bitset)使用指南

在C++标准模板库(STL)中,std::bitset是一个固定大小的位集合,它提供了一种紧凑且方便的方式来存储和操作二进制位。本课将详细介绍std::bitset的使用方法,并通过示例代码展示其在不同场景下的应用。

1. std::bitset概述

std::bitset是一个模板类,它根据模板参数指定的位数来创建一个位集合。

示例代码
#include <bitset>int main() {std::bitset<8> b; // 创建一个有8位的bitsetb.set(); // 将所有位设置为1return 0;
}

2. 初始化std::bitset

std::bitset可以通过多种方式初始化,包括直接初始化、拷贝初始化和使用位模式初始化。

示例代码
std::bitset<8> b1(0xFF); // 使用整数初始化
std::bitset<8> b2 = b1; // 拷贝初始化
std::bitset<8> b3{1, 0, 1, 0, 1, 0, 1, 0}; // 使用花括号初始化

3. 访问和修改位

std::bitset提供了多种方法来访问和修改单独的位。

示例代码
b.flip(); // 翻转所有位
b.set(2); // 将第3位设置为1
b.reset(2); // 将第3位重置为0
b.flip(2); // 翻转第3位

4. 位操作

std::bitset支持位运算,包括AND、OR、XOR和NOT。

示例代码
std::bitset<8> b1(0xFF);
std::bitset<8> b2(0x00);
std::bitset<8> b3 = b1 & b2; // AND操作

5. 遍历std::bitset

可以使用迭代器或循环来遍历std::bitset中的所有位。

示例代码
for (bool bit : b) {std::cout << bit;
}

6. std::bitset的大小和容量

std::bitset的大小由模板参数决定,并且提供了容量查询的方法。

示例代码
std::size_t size = b.size(); // 获取bitset的大小

6. std::bitset的非成员函数

STL提供了一些非成员函数,如operator<<operator>>,用于与std::bitset交互。

示例代码
std::cin >> b; // 从标准输入读取bitset
std::cout << b << std::endl; // 输出bitset到标准输出

7. std::bitset的实际应用

通过实际案例展示std::bitset在项目中的应用,如状态存储、权限控制等。

示例代码
std::bitset<5> permissions; // 存储文件权限
permissions.set(2); // 设置可写权限

在C++ STL中,除了位集合(std::bitset)之外,还有一些其他的组件和概念对于理解和掌握STL至关重要。

8. 正则表达式 (std::regex)

正则表达式是一种用于字符串搜索和操作的强大工具,C++11标准引入了正则表达式库。

示例代码
#include <regex>
#include <string>bool isMatch(const std::string& text, const std::regex& pattern) {return std::regex_match(text, pattern);
}

9. 流迭代器 (std::istream_iteratorstd::ostream_iterator)

流迭代器允许你直接从流中读取或写入数据,而不需要逐个元素地处理。

示例代码
#include <iterator>
#include <vector>
#include <algorithm>
#include <iostream>int main() {std::vector<int> vec = {1, 2, 3, 4, 5};std::copy(vec.begin(), vec.end(), std::ostream_iterator<int>(std::cout, " "));return 0;
}

10. 配对和元组 (std::pairstd::tuple)

std::pairstd::tuple 提供了一种存储固定数量元素组的方法。

示例代码
#include <utility>int main() {std::pair<int, std::string> p(1, "one");std::tuple<int, double, char> t(1, 2.5, 'A');return 0;
}

11. 函数对象和仿函数 (std::functionstd::bind)

函数对象是重载了函数调用运算符的类的实例。std::function是一个通用的多态函数封装器。

示例代码
#include <functional>
#include <algorithm>
#include <vector>int main() {std::vector<int> vec = {1, 2, 3, 4, 5};auto is_even = [](int i) { return i % 2 == 0; };auto it = std::find_if(vec.begin(), vec.end(), is_even);if (it != vec.end()) {std::cout << "Found even number: " << *it << std::endl;}return 0;
}

12. 右值引用和移动语义

C++11引入了右值引用和移动语义,它们提供了对资源管理的更精细控制。

示例代码
#include <utility>template<typename T>
class Resource {
public:Resource(T t) : data(std::move(t)) {}// ...
private:T data;
};

13. 变长模板(Variadic Templates)

变长模板允许模板定义接受任意数量的模板参数。

示例代码
template<typename... Args>
void printAll(Args... args) {(std::cout << ... << args) << std::endl;
}

14. 并发编程支持

C++标准库提供了并发编程的支持,包括线程库、原子操作、锁等。

示例代码
#include <thread>
#include <vector>void doWork(int n) {// Do some work
}int main() {std::vector<std::thread> threads;for (int i = 0; i < 10; ++i) {threads.emplace_back(doWork, i);}for (auto& th : threads) {th.join();}return 0;
}

15. 智能指针

智能指针提供了自动内存管理,减少了内存泄漏的风险。

示例代码
#include <memory>int main() {auto ptr = std::make_shared<int>(10); // 创建一个shared_ptrstd::weak_ptr<int> weakPtr = ptr;     // 创建一个weak_ptr// 使用ptr和weakPtrreturn 0;
}

16. 条件变量和原子操作

条件变量和原子操作是并发编程中同步线程的重要工具。

示例代码
#include <mutex>
#include <condition_variable>std::mutex mtx;
std::condition_variable cv;
bool ready = false;void worker() {std::unique_lock<std::mutex> lck(mtx);cv.wait(lck, []{ return ready; }); // 等待条件// 条件满足后的工作
}int main() {// 设置数据,通知worker开始工作std::thread t(worker);ready = true;cv.notify_one();t.join();return 0;
}

结语

通过本课的学习,你深入了解了STL中的std::bitset,包括其初始化、位访问和修改、位操作、遍历、大小和容量查询、非成员函数的使用、实际应用、线程安全性和性能考量。

std::bitset是C++中处理位集合的强大工具,它在需要紧凑存储和快速访问位的场景下非常有用。掌握std::bitset的使用对于编写高效、可维护的C++程序至关重要。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/833847.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第七届机电、机器人与自动化国际会议(ICMRA 2024)即将召开!

第七届机电、机器人与自动化国际会议&#xff08;ICMRA 2024&#xff09;将于2024年9月20日-22日在中国武汉举行。ICMRA 2024为各国专家学者提供一个学术交流的平台&#xff0c;讨论机电、机器人和自动化领域的最新研究成果和未来的研究方向&#xff0c;旨在能够建立起国家间&a…

Ansible剧本playbook之--------Templates 模块、roles角色详细解读

目录 一、Templates 模块 1.1准备模板文件并设置引用的变量 1.2修改主机清单文件&#xff0c;使用主机变量定义一个变量名相同&#xff0c;而值不同的变量 1.3编写 playbook 1.4ansible主机远程查看修改参数 1.5验证 二、tags 模块 always应用 三、Roles 模块 3.1ro…

在国企分公司做信息宣传新闻投稿的经验分享

作为一名国企分公司的信息宣传工作者,我亲历了从传统投稿方式到数字化转型的全过程,这段经历既充满了挑战,也收获了成长。回首最初的日子,那些用邮箱投稿的时光,至今仍让我感慨万千。 初尝辛酸,邮箱投稿的艰难岁月 刚接手信息宣传工作时,我满腔热情,却很快被现实的冷水浇了个透…

RabbitMQ的五种模式

一、简单模式 简单模式&#xff08;Simple&#xff09;&#xff1a;一个生产者&#xff0c;一个消费者 package com.qiangesoft.rabbitmq.mode.simple;import lombok.extern.slf4j.Slf4j; import org.springframework.amqp.rabbit.annotation.Queue; import org.springframe…

事业单位向媒体投稿发文章上级领导交给了我投稿方法

作为一名事业单位的普通职员,负责信息宣传工作,我见证了从传统投稿方式到智能化转型的全过程,这段旅程既是一次挑战,也是一次宝贵的成长。回想起初涉此领域的日子,那些通过邮箱投稿的时光,至今仍然历历在目,其中的酸甜苦辣,构成了我职业生涯中一段难忘的经历。 邮箱投稿:费时费…

C++从入门到精通---模版

文章目录 泛型编程函数模版模版参数的匹配原则类模版类模版的定义格式类模版的实例化 总结 泛型编程 泛型编程是一种编程范式&#xff0c;旨在实现通用性和灵活性。它允许在编写代码时使用参数化类型&#xff0c;而不是具体的类型&#xff0c;从而使代码更加灵活和可重用。 在…

spring ioc 容器加载过程 refresh() 方法详解

IOC 加载过程 从 new ClassPathXmlApplicationContext开始 ApplicationContext context new ClassPathXmlApplicationContext("classpath:application.xml");ClassPathXmlApplicationContext类构造方法 public ClassPathXmlApplicationContext(String[] configLo…

Redis集群分片

什么是集群 集群是由多个复制集组成的,能提供在多个redis节点间共享数据的程序集 简而言之就是将原来的单master主机拆分为多个master主机,将整个数据集分配到各主机上 集群的作用 集群中可以存在多个master,而每个master可以挂载多个slave自带哨兵的故障转移机制,不需要再去…

Python解释器3.8.2版本安装详细教程

Python解释器提取链接链接&#xff1a; https://pan.baidu.com/s/1eDvwYmUJ4l7kIBXewtN4EA?pwd1111 提取码&#xff1a;1111 演示版本为3.6.8&#xff0c;链接安装包为3.8.2版&#xff0c;包中附加pytharm安装包。 1.双击提取好的python-exe安装文件&#xff0c;会…

外企接受大龄程序员吗?

本人知乎账号同公众号&#xff1a;老胡聊Java&#xff0c;欢迎留言并咨询 亲身体会外企经历所见所闻&#xff0c;外企能接受大龄程序员。 1 大概是10年的时候&#xff0c;进一家知名外企&#xff0c;和我一起进的一位manager&#xff0c;后来听下来&#xff0c;年龄35&#xf…

0508_IO3

练习1&#xff1a; 1&#xff1a;使用 dup2 实现错误日志功能 使用 write 和 read 实现文件的拷贝功能&#xff0c;注意&#xff0c;代码中所有函数后面&#xff0c;紧跟perror输出错误信息&#xff0c;要求这些错误信息重定向到错误日志 err.txt 中去 1 #include <stdio.h…

【matlab基础知识代码】(十二)逆矩阵与广义逆矩阵

>> Hhilb(4);H1inv(H),norm(H*H1-eye(4))H1 1.0e03 *0.0160 -0.1200 0.2400 -0.1400-0.1200 1.2000 -2.7000 1.68000.2400 -2.7000 6.4800 -4.2000-0.1400 1.6800 -4.2000 2.8000ans 2.8455e-13 矩阵维数较大&#xff0c;警告: 矩阵接近奇…

svg画扇形进度动画

有人问下面这种图好怎么画&#xff1f;svg 想了下&#xff0c;确实用svg可以&#xff0c;可以这么设计 外层是一个容器放置内容&#xff0c;并且设置overflow:hidden&#xff0c; 内层放一个半径大于容器宽高一半的svg&#xff0c;并定位居中&#xff0c;然后svg画扇形&#x…

线程的组成、执行特点、创建的两种方式

线程的组成&#xff1a; cpu时间片 运行内存&#xff1a;栈、堆 线程的逻辑代码 线程执行的特点&#xff1a; 抢占式执行&#xff0c;结果随机&#xff0c;效率高&#xff0c;可以防止单一线程长时间独占CPU 在单核cpu中&#xff0c;宏观上同时执行&#xff0c;微观上顺序…

C++青少年简明教程之一:基础知识

C青少年简明教程之一&#xff1a;基础知识 电脑程序设计&#xff08;Computer programming&#xff09;&#xff0c;或称程序设计&#xff08;programming&#xff09;&#xff0c;是给出解决特定问题程序的过程&#xff0c;程序设计往往以某种程序设计语言为工具&#xff0c;给…

【软件测试】用例篇 -- 详解

一、测试用例的基本要素 测试用例&#xff08;Test Case&#xff09;是为了实施测试而向被测试的系统提供的一组集合&#xff0c;这组集合包含&#xff1a;测试环境、操作步骤、测试数据、预期结果等要素。&#xff08;注意&#xff1a;不需要执行结果&#xff0c;因为执行结果…

IO 5.8日

1&#xff1a;使用 dup2 实现错误日志功能 使用 write 和 read 实现文件的拷贝功能&#xff0c;注意&#xff0c;代码中所有函数后面&#xff0c;紧跟perror输出错误信息&#xff0c;要求这些错误信息重定向到错误日志 err.txt 中去 2&#xff1a;判断一个文件是否拥有用户可写…

Android单行字符串末尾省略号加icon,图标可点击

如图 设置仅显示单行字符串&#xff0c;末尾用省略号&#xff0c;加跟一个icon&#xff0c;icon可点击 tvName.text "test"val drawable ResourcesCompat.getDrawable(resources, R.mipmap.icon_edit, null)tvName.setCompoundDrawablesWithIntrinsicBounds(null,…

【如此简单!数据库入门系列】之无序不代表混乱 -- 堆文件

文章目录 前言堆文件链表实现页目录实现总结系列文章 前言 还记得上次遗留的问题吗&#xff1f; 以什么组织方式将数据保存在磁盘中&#xff1f; 今天我们接着讨论这个问题。 首先想一个问题&#xff1a;有一天&#xff0c;你开着自己心爱的大型SUV去超市购物。在停车场入口看…

威客网上招标系统(五)

目录 5 详细设计 5.1 系统首页 5.1.1系统首页&#xff08;网站首页index.jsp&#xff09; 5.1.2 下沙派威客网首页界面说明 5.2 站内新闻信息 5.2.1站内新闻操作界面 5.2.2系统主操作界面说明 5.3威客在线操作界面 5.3.1 威客在线操作界面 5.3.2威客在线说明 5.4系统…