当前位置: 首页 > article >正文

boost.asio

as(async):异步 

同步io: 

 reactor (非阻塞)(需要注册一次,在等待消息时可以干别的事)   阻塞io网络模型

接口:read\accept\connect\write                接口返回时,io完成

异步io:

iocp (多次投递请求,给菜鸟驿站篮子,让菜鸟驿站把篮子和货物一起送过来)

接口上:WSARecv\AcceptEc\ConnectEx\WSASend    接口返回时,io并未完成

工作中的运用,基于抽象的模型解决问题:

两个命名空间:

boost::aiso

提供核心类以及重要函数

io_context(io上下文):相当于reactor中的对象,相当于windows中IOCP对象

iocp:1.创建一个具体的socket  2.创建一个完成端口,socker绑定在完成端口上

boost::aiso  : 如果socket要异步处理io,必须把socket跟io_context进行绑定

reactor   : epoll   检测  就绪                      非阻塞 io : 操作io(事件循环中处理)

重要函数:

封装的: 同步io函数:posix api类似  标准api:connect    accept    read_some    write_some

                异步io函数:  api     async_connect    async_accept    async_read_some                                                    async_write_some

boost::asio::ip             使用这个命名空间操作协议栈

1.ip地址的封装           ip地址:  ip::address

                                    端点:     ip::tcp::endpoint \  ip::udp::endpoint

服务端绑定:IP port          1.ipv4/ipv6   2.tcp/udp           3.给定具体的端口

socket:     ip::tcp::socket       ip::udp::socket

套接字控制:   set_option  设置套接字属性

                        get_option   

                        io_control    在套接字上执行io指令

cmake 来构建boost.asio应用

boost::system

同步io函数:抛异常   获取错误码

connect(socket,boost::system::error_code err)

异步io函数: buffer(篮子)boost::asio::buffer

                       回调函数:

异步读取数据 :准备一个篮子,如果操作系统帮我们把这个数据都出来后 ,并且填充到里面后 ,会回调函数  :没出错的话:会告诉你往这个篮子放了多长的数据  ,出错了的话:error可以告诉我们没有读取到数据的原因    

篮子就是回调函数,在数据传输完成后会自动触发

async_read_some(buffer(data,lenght)),[](boost::system::error_code err,size_t transferedBytes){

};

创建文件后,根目录是CMakeLists.txt 里面的project相当于解决方案的名字.sln

boost都是以头文件来提供库 #include "asio.h"   #include <boost/asio.hpp>

using namespace boost::asio;

using namespace boost::asio::ip;

io_context相当于reactor对象也相当于一个iocp的对象   io_ctx.run()相当于react中的事件循环,相当于iocp当中的不断地阻塞,等待,完成通知

事件循环:先注册一个事件后,会有不断地事件循环,检测io就绪之后再去操作io

iocp中先投递一个请求到iocp中,iocp会去帮我们完成,然后通知 另外一个线程(这个线程就是一个死循环,不断地从iocp这个完成队列当中取出完成事件)

最开始学习网络编程的思路:

server:首先创建一个socket,是一个listensocket,主要目的是用来接受客户端的连接,bind绑定一个具体的地址,listen用于监听,监听完之后既可以用于接受连接

不同的网络模型,这里的流程都是一摸一样的

boost.asio直接封装了一个对象,这个对象就是acceptor,直接用一个对象进行封装了,acceptor本质上而言是一个socket,所有的socket必须要绑定io_context,否则不能在它的基础上展开异步操作

在这个编程的过程中我们需要进行一个封装,直接使用这个acceptor不太好处理,因为我们在这里接下来会有异步操作,接着又要投递异步操作。对于异步操作而言,虽然io操作不是我们自己的,不是在用户态完成的,但是需要投递一次,完成一次,不是像rector网络编程,他是注册一次,未来只要有数据它就通知你。异步编程或者是boost.asio不会这么灵敏,必须要你投递才会去完成你的事情,否则是不会动的,因为要反复投递,直接用这个对象封装是不太好的。直接去封装一个server,作用是不断接受客户端的连接

//智能指针
include <memory>//因为要反复进行投递,所以我们要封装一个对象class Session:public std::enable_sharder_from_this<Session >
{
public::Session(tcp::socket sock) socket_move(sock))//链接不能拷贝复制,把socket里面的系统资源移动到这个Session里面的socket上面,移动完后,这个sock就会被析构{}
哪些操作:void Start(){
//开始读数据
do_read();
private:void do_close(){boost::system::error_code err;
socket_.close(err);
}  }void do_read(){auto self(shared_from_this())
//不断地异步的去读数据
socket_async_read_some(buffer(readBuffer_,max_packet_len),//后面是具体的回调函数[this,self](boost::system::error_code err,size_t transfered){if(err){do close;return;} //希望回调函数调用时,这个socket_依然存在,则使用智能指针do_read();});void do_write(){auto self(shared_from_this())socket_async_read_some(buffer(readBuffer_,max_packet_len),[this,self](boost::system::error_code,size_t transfered)
{if(err){
do_close();
return ;
}
do_read();
}
}}
}
private:tcp::socket socket_;enum  readBuffer_{max_packet_len=1024};};//不断接收客户端的连接
class Server{
public:server(io_context,short port) :acceptor_(io_ctx,tcp::endpoint(tcp::v4(),port))
{//这当中应该要不断地投递出异步请求
}
private:void do_accept(){acceptor_.async.accept([this](boost::system::error_code err,tcp::socket sock){//在这里进行判断是否出现错误,如果没有出现错误,我们就接受了一条新的连接,那我们就需要构建连接,继续进行封装,本来直接在这个sock上抛出异步读数据的请求,进行网络编程,当我们接收到一个客户端的连接之后,要循环往复在这个连接上读数据写数据,一直到这条连接断开为止,所以要基于这个sock反复地去投递不同地读请求或者是写请求 ,所以給这个sock也封装一个对象if(!err)
{std::make_shared<Session>(sock)->Start();
}})
//第一个参数是一个具体的回调函数,直接给一个回调函数就行了
//第二个参数接受具体的连接,它会直接帮我们构建一个socket
}
//构造函数,server中只有一个变量acceptor_,所以需要
//把io_context传进去,否则构造不会成功,在acceptor上抛异步请求,
//必须要有一个io_context,这个iocontext是我们这个boost.asio命名空间中帮我们构建的
//作为服务端还需要绑定一个端口port
private:tcp::acceptor acceptor_;//不断地抛接收连接的请求};

网络模型可分为以下两大类:

  1. 阻塞/同步模型

    • 线程阻塞等待IO操作完成

    • 典型代表:传统阻塞IO模型

    • 问题:线程资源消耗大,扩展性差

  2. 非阻塞/异步模型

    • Reactor模式:同步非阻塞+事件驱动

    • Proactor模式:异步IO+事件驱动

    • 特点:高并发、资源利用率高

 Boost.Asio

  • 设计特点

    • 跨平台抽象(Windows用IOCP,Linux用epoll)

    • Proactor模式接口,Reactor模式实现(Linux)

    • 支持协程(C++20后)

相关文章:

boost.asio

as&#xff08;async&#xff09;:异步 同步io&#xff1a; reactor (非阻塞)&#xff08;需要注册一次&#xff0c;在等待消息时可以干别的事&#xff09; 阻塞io网络模型 接口&#xff1a;read\accept\connect\write 接口返回时&#xff0c;io完成 异步…...

当贝AI知识库评测 AI如何让知识检索快人一步

近日,国内领先的人工智能服务商当贝AI正式推出“个人知识库”功能,这一创新性工具迅速引发行业关注。在信息爆炸的时代,如何高效管理个人知识资产、快速获取精准答案成为用户的核心需求。当贝AI通过将“闭卷考试”变为“开卷考试”的独特设计,为用户打造了一个高度个性化的智能…...

格雷码、汉明码,CRC校验的区别

格雷码、汉明码和CRC校验都是用于数据传输和存储中的编码技术。 它们在原理、功能和应用场景上存在显著区别。 1.格雷码&#xff08;Gray Code&#xff09; • 定义&#xff1a;格雷码是一种特殊的二进制编码&#xff0c;任意两个相邻的码字之间仅有一位不同。 • 功能&#x…...

uvm configuration

UVM Configuration 机制详解 UVM 的 配置机制&#xff08;Configuration Mechanism&#xff09; 是验证环境中实现参数传递和动态配置的核心方法&#xff0c;通过 uvm_config_db 类实现跨组件的数据共享和灵活配置。以下是其核心概念、使用方法和最佳实践的详细解析&#xff1…...

nginx配置页面缓存,前端每次打包生成新的js文件

前端需要处理的&#xff1a;使用时间戳作为文件名 // nuxt.config.js export default {build: {filenames: {app: ({ isDev }) > isDev ? [name].js : [name].${Date.now()}.js, // 生产环境用时间戳chunk: ({ isDev }) > isDev ? [name].js : [name].${Date.now()}.j…...

Google开源机器学习框架TensorFlow探索更多ViT优化

一、在边缘设备优化ViTa 在边缘设备上优化 ViT&#xff08;Vision Transformer&#xff09;模型&#xff0c;主要目标是减少计算量、降低功耗、提升推理速度。以下是几种关键优化策略&#xff1a; 1.轻量级 ViT 变体 部分 ViT 变体专为边缘设备优化&#xff0c;包括&#xf…...

深度解读:智能体2.0 AI Agent多推演进

AI Agent即AI 代理&#xff0c;长期以来&#xff0c;研究人员一直在追求更完美的AI&#xff0c;可以与人类相当、甚至是超越人类。在1950年代&#xff0c;AIan Turing就将“智能”的概念扩展到了人工实体&#xff0c;并提出了著名的图灵测试。这些人工智能实体就被称为——Agen…...

Docker Swarm 和 docker composer 需要 的yaml 文件有什么区别

Docker Compose 和 Docker Swarm 都使用 YAML 文件来定义服务、网络和卷的配置&#xff0c;但它们的 YAML 文件格式和功能有一些关键区别。以下是它们的主要区别&#xff1a; 1. 文件格式 Docker Compose&#xff1a; 使用 docker-compose.yml 文件。支持的版本号通常为 2.x 或…...

Golang 的 GMP 调度机制常见问题及解答

文章目录 Golang GMP 调度模型详解常见问题基础概念1. GMP 各组件的作用是什么&#xff1f;2. 为什么 Go 需要自己的调度器&#xff1f;3. GOMAXPROCS 的作用是什么&#xff1f; 调度流程4. Goroutine 如何被调度到 M 上执行&#xff1f;5. 系统调用会阻塞整个线程吗&#xff1…...

项目-苍穹外卖(十五) Apache ECharts+数据统计

一、介绍 二、营业额统计 需求分析和设计&#xff1a; Controller: Service: /*** 营业额统计* param begindate* param enddate* return* */Overridepublic TurnoverReportVO turnoverStatistics(LocalDate begindate, LocalDate enddate) {//创建时间集合List<LocalDate&…...

Windows 10/11 使用 VSCode + SSH 免密远程连接 Ubuntu 服务器(指定端口)

摘要&#xff1a; 本文详细介绍如何在 Windows 系统上通过 VSCode Remote-SSH 免密登录远程 Ubuntu 服务器&#xff08;SSH 端口 2202&#xff09;&#xff0c;避免每次输入密码的繁琐操作&#xff0c;提高开发效率。 1. 环境准备 本地系统&#xff1a;Windows 10/11远程服务…...

【9】Strongswan collections —— enumerator

//以目录枚举为例子&#xff0c;说明enumerator&#xff0c;从源码剥离可运行 #include <stdio.h> #include <stdbool.h> #include <dirent.h> #include <errno.h> #include <string.h> #include <sys/types.h> #include <sys/stat.h&…...

大数据学习(88)-zookeeper实现的高可用(HA)

&#x1f34b;&#x1f34b;大数据学习&#x1f34b;&#x1f34b; &#x1f525;系列专栏&#xff1a; &#x1f451;哲学语录: 用力所能及&#xff0c;改变世界。 &#x1f496;如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏⭐️留言&#x1f4dd;支持一…...

Spring Data审计利器:@LastModifiedDate详解(依赖关系补充篇)!!!

&#x1f552; Spring Data审计利器&#xff1a;LastModifiedDate详解&#x1f525;&#xff08;依赖关系补充篇&#xff09; &#x1f50c; 核心依赖解析 使用LastModifiedDate必须知道的依赖关系 #mermaid-svg-qm1OUa9Era9ktbeK {font-family:"trebuchet ms",verd…...

Tweak Power:全方位电脑系统优化的高效工具

Tweak Power&#xff08;系统&#xff09; Tweak Power是一款功能强大的系统优化工具&#xff0c;专为提升Windows电脑的性能和稳定性而设计。它提供了全面的清理、优化和调整选项&#xff0c;帮助用户轻松管理系统资源、提高运行速度、延长设备寿命。 快速扫描并清理系统垃圾…...

CLion下载安装(Windows11)

目录 CLion工具下载安装其他 CLion CLion-2024.1.4.exe 工具 系统&#xff1a;Windows 11 下载 1.通过百度网盘分享的文件&#xff1a;CLion-2024.1.4.exe 链接&#xff1a;https://pan.baidu.com/s/1-zH0rZPCZtQ60IqdHA7Cew?pwdux5a 提取码&#xff1a;ux5a 安装 打开…...

如何用 Postman 进行高效的 Mock 测试?

Postman 是一个强大的 API 开发和测试工具&#xff0c;它可以让你轻松地创建和发送各种 HTTP 请求&#xff0c;查看响应结果&#xff0c;并进行调试和优化。但是有时候&#xff0c;你可能还没有开发好后端服务&#xff0c;或者想要模拟不同的响应场景&#xff0c;这时候就可以使…...

DeepSeek API集成开发指南——Flask示例实践

DeepSeek API集成开发指南——Flask示例实践 序言&#xff1a;智能化开发新范式 DeepSeek API提供了覆盖自然语言处理、代码生成等多领域的先进AI能力。本文将以一个功能完备的Flask示例系统为载体&#xff0c;详解API的集成方法与最佳实践。通过本案例&#xff0c;开发者可快…...

【天梯赛】L2-004 这是二叉搜索树吗(经典问题C++)

解题反思 //镜像树满足&#xff1a;左子树>根节点>右子树 //特殊&#xff1a;独腿二叉树&#xff0c;如pre {2&#xff0c;3&#xff0c;4}&#xff0c;递归函数用if(root tail) return&#xff1b;无法识别这种二叉树 // 用ismirror来将一般二叉树和镜像二叉搜索树的…...

Postman 全局 Header 如何设置?全局设置了解一下

在使用 Postman 设置全局请求头信息的关键步骤包括&#xff1a;在集合设置页面中添加所需的头部信息&#xff0c;并确保选择适当的类型和值&#xff1b;如果需要&#xff0c;可通过 JavaScript 脚本添加其他请求头&#xff1b;最后&#xff0c;验证设置是否成功生效。 Postman…...

科技赋能建筑业变革:中建海龙创新引领高质量发展新路径

在建筑工业化浪潮中&#xff0c;中建海龙科技有限公司&#xff08;以下简称“中建海龙”&#xff09;凭借深厚的技术积累与持续创新&#xff0c;成为推动行业转型升级的标杆企业。作为中国建筑国际集团旗下核心科技力量&#xff0c;中建海龙深耕模块化集成建筑&#xff08;MiC&…...

QT计算器开发

1.项目架构 1.图形化界面 ​ 2.widget.h​ #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QString> #include <QStack>QT_BEGIN_NAMESPACE namespace Ui { class Widget; } QT_END_NAMESPACEclass Widget : public QWidget {Q_OBJECTp…...

R语言对偏态换数据进行转换(对数、平方根、立方根)

我们进行研究的时候经常会遇见偏态数据&#xff0c;数据转换是统计分析和数据预处理中的一项基本技术。使用 R 时&#xff0c;了解如何正确转换数据有助于满足统计假设、标准化分布并提高分析的准确性。在 R 中实现和可视化最常见的数据转换&#xff1a;对数、平方根和立方根转…...

《Python实战进阶》No37: 强化学习入门:Q-Learning 与 DQN-加餐版1 Q-Learning算法可视化

在《Python实战进阶》No37: 强化学习入门&#xff1a;Q-Learning 与 DQN 这篇文章中&#xff0c;我们介绍了Q-Learning算法走出迷宫的代码实践&#xff0c;本文加餐&#xff0c;把Q-Learning算法通过代码可视化呈现。我尝试了使用Matplotlib实现&#xff0c;但局限于Matplotli…...

【漏洞修复】Android 10 系统源码中的 glibc、curl、openssl、cups、zlib 更新到最新版本

要将 Android 10 系统源码中的 glibc、curl、openssl、cups、zlib 更新到最新版本&#xff0c;需结合交叉编译、源码替换和系统兼容性适配。以下是具体步骤和相关库的版本信息及维护状态分析&#xff1a; 一、Android 10 默认版本及维护状态 库Android 10 默认版本维护状态最新…...

【云服务器】在 Linux(Ubuntu / CentOS 7)上快速搭建我的世界 Minecraft 服务器,并实现远程联机,详细教程

【云服务器】在 Linux&#xff08;Ubuntu / CentOS 7&#xff09;上快速搭建我的世界 Minecraft 服务器&#xff0c;并实现远程联机&#xff0c;详细教程 一、 服务器介绍二、下载 Minecraft 服务端二、安装 JRE 21三、安装 MCS manager 面板四、搭建服务器五、本地测试连接六、…...

docker torcherve打包mar包并部署模型

使用Docker打包深度网络模型mar包到服务端 参考链接&#xff1a;Docker torchserve 部署模型流程——以WSL部署YOLO-FaceV2为例_class myhandler(basehandler): def initialize(self,-CSDN博客 1、docker拉取环境镜像命令 docker images出现此提示为没有权限取执行命令&…...

【安当产品应用案例100集】042-基于安当KADP实现机密文件安全流转

一、客户需求 某集团公司客户&#xff0c;在系统业务流中&#xff0c;存在大量的内部文件流转的需求。内部业务文件有不同的安全密级&#xff0c;最初在文件流转时&#xff0c;公司内部规定点对点的文件传输&#xff0c;要使用加密工具加密后再发给需要的一方。这种方式虽然能…...

[Qt5] QMetaObject::invokeMethod使用

&#x1f4e2;博客主页&#xff1a;https://loewen.blog.csdn.net&#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;本文由 丶布布原创&#xff0c;首发于 CSDN&#xff0c;转载注明出处&#x1f649;&#x1f4e2;现…...

软件设计原则之迪米特法则

迪米特法则&#xff08;Law of Demeter&#xff0c;LoD&#xff09; 核心思想&#xff1a; 一个对象应当尽可能少地了解其他对象&#xff0c;只与直接朋友交互&#xff08;如自身的成员变量、方法参数、方法内部创建的对象&#xff09;&#xff0c;避免通过复杂的调用链访问间…...