boost::asio 学习
安装
- 下载-解压
- 指定安装目录
./bootstrap.sh --prefix=/usr/local/boost_1_68_0
- 查看所有必须要编译才能使用的库
./b2 --show-libraries
- 其他编译选项
./b2 --help- 只编译安装date_time库:
./b2 --with-date_time --buildtype=complete install
Proactor 设计模式
- 操作系统的 异步读写
- 异步读写在调用的时候可以 传递回调函数 或者 回送信号
- 当异步操作完毕,内核会自动调用回调函数或者发送信号
- 异步操作
- 定义一个异步执行操作,如Socket异步读写
- 异步操作处理器
- 执行 异步操作并在操作完成后,
- 执行 完成事件队列 中的 队列事件 (将事件加入完成事件队列?)
- 完成事件队列
- 缓冲 完成事件,直到被 异步事件信号分离器 移出队列
- 完成句柄(handler)
- 处理 异步操作的 结果
- 这是一个函数对象,通常使用boost::bind创建.
- 异步事件信号分离器
- 在 完成事件队列 中阻塞等待事件,受信后向调用者返回完成事件
- Proactor
- 调用 __异步事件信号分离器__将事件移出队列
- 并为这个事件分配一个完成句柄(如调用函数对象,这个功能封装在io_service类中)
- 初始化器?
- 执行特定程序代码启动异步操作.初始化器通过如basic_stream_socket等高层次接口与异步操作处理器交互,其返回stream_socket_service等类型的服务代理.
handler
- 符合某种函数签名的 回调函数
- 事件 对应 handler
- 可拷贝(io_service存储handler的拷贝,发生异步事件时调用)
- 可以是函数、函数指针、函数对象、function对象、bind/lambda表达式等
io_service
- 异步平台
- 负责连接 应用程序 与 操作系统 的IO服务
- 代表操作系统里的 异步处理机制 (如epoll)
- asio库中的其他对象 向io_service对象提交异步操作的handler
- run()成员函数
- 启动事件循环
- 阻塞等待所有注册到io_service的事件完成
- 阻塞未完成的异步操作
strand ?
- boost::asio中自己的线程概念
- 序列化异步操作?
- 保证异步代码在多线程的环境中可以正确的执行?
不需要互斥量
可以理解为是一组handler的锁(多个线程对一个io_service对象执行run()时,strand来保证不存在线程并发访问的问题)
IO操作的数据缓冲区
- mutable_buffer
- const_buffer
signal_set
- add()成员函数
- 向signal_set添加要捕获的信号
- 向io_service注册 信号事件
- async_wait()成员函数
- 通知io_service 异步 的执行IO操作
- 向io_service注册 信号处理函数
定时器
参考资料
两种高性能 I/O 设计模式 Reactor 和 Proactor
Boost.Asio基本原理
boost::asio中文文档 Boost.Asio概念图
为什么异步处理还要调用阻塞式的 run() 方法
boost::asio 学习的更多相关文章
- boost asio 学习(一)io_service的基础
原文 http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting- started-with-boostasio/ 编译环境 b ...
- boost asio 学习(九) boost::asio 网络封装
http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting- started-with-boostasio?pg=10 9. A ...
- boost asio 学习(八) 网络基础 二进制写发送和接收
http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting- started-with-boostasio?pg=9 8. Net ...
- boost asio 学习(七) 网络基础 连接器和接收器(TCP示例)
http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting- started-with-boostasio?pg=8 7. Net ...
- boost asio 学习(六) 定时器
http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting- started-with-boostasio?pg=7 6 定时器 ...
- BOOST ASIO 学习专贴
本文已于20170903更新完毕,所有boost asio 代码均为本人手抄.编译器为vs2013,并且所有代码已经上传,本文下方可下载源码 为了学习boost asio库,我是从boost的官方bo ...
- boost asio 学习(五) 错误处理
http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting-started-with-boostasio?pg=6 5. Erro ...
- boost asio 学习(四)使用strand将任务排序
http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting-started-with-boostasio?pg=5 4. Seri ...
- boost asio 学习(三)post与dispatch
http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting-started-with-boostasio?pg=4 本章节为io_ ...
随机推荐
- “数据上帝” Jeff Hammerbacher
出生于1983年的数学天才Jeff Hammerbacher在23岁时加入了Facebook,一手组建起数据分析队伍.他是“数据科学”(data science)一词的提出者之一,被人们称为“数据上帝 ...
- set_false_path的用法
set_false_path的用法 非功能性路径,因为两个多路选择器被相同的选择信号驱动? 上电复位信号 set_false两个异步时钟域的路径 在两个时钟域之间,设置set_false_path,应 ...
- Kafka 配置安装
1.从官网下载安装包 http://kafka.apache.org/downloads2.上传到01虚拟机,解压3.进入安装目录下的config目录4.对server.properties进行配置 ...
- pytorch学习资料链接
2017年12月25日15:06:44 官方文档:http://pytorch.org/docs/master/index.html 官方文档中文翻译:https://pytorch-cn.readt ...
- dubbo文档
Srping版Dubbo集成中文地址: https://dubbo.gitbooks.io/dubbo-user-book/content/preface/background.html Spring ...
- Dubbo基本原理机制
分布式服务框架: –高性能和透明化的RPC远程服务调用方案 –SOA服务治理方案 -Apache MINA 框架基于Reactor模型通信框架,基于tcp长连接 Dubbo缺省协议采用单一长连接和 ...
- android 开发 View _9_ 实现渐变功能(直线与圆形)
参考博客:https://blog.csdn.net/iispring/article/details/50500106/ android颜色渐变的分类有: LinearGradient线性渐变 线性 ...
- linux 查看端口被占用
linux 查看端口被占用 1.lsof -i : 端口号 用于查看某一端口的占用情况,比如查看8080端口使用情况,lsof -i:8080 如果执行 lsof -i:8080 系统提示 : ...
- 代码: !AJAX
http://www.cnblogs.com/cwp-bg/p/7668840.html ajax和jsonp使用总结 2017-10-17 var requestUrl="http://l ...
- Innodb锁相关总结
一.InnoDB共有七种类型的锁: (1)共享/排它锁(Shared and Exclusive Locks) (2)意向锁(Intention Locks) (3)插入意向锁(Insert Inte ...