安装

  • 下载-解压
  • 指定安装目录
    • ./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 学习的更多相关文章

  1. boost asio 学习(一)io_service的基础

    原文  http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting- started-with-boostasio/ 编译环境 b ...

  2. boost asio 学习(九) boost::asio 网络封装

    http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting- started-with-boostasio?pg=10 9. A ...

  3. boost asio 学习(八) 网络基础 二进制写发送和接收

    http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting- started-with-boostasio?pg=9 8. Net ...

  4. boost asio 学习(七) 网络基础 连接器和接收器(TCP示例)

    http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting- started-with-boostasio?pg=8 7. Net ...

  5. boost asio 学习(六) 定时器

    http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting- started-with-boostasio?pg=7 6 定时器 ...

  6. BOOST ASIO 学习专贴

    本文已于20170903更新完毕,所有boost asio 代码均为本人手抄.编译器为vs2013,并且所有代码已经上传,本文下方可下载源码 为了学习boost asio库,我是从boost的官方bo ...

  7. boost asio 学习(五) 错误处理

    http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting-started-with-boostasio?pg=6 5. Erro ...

  8. boost asio 学习(四)使用strand将任务排序

    http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting-started-with-boostasio?pg=5 4. Seri ...

  9. boost asio 学习(三)post与dispatch

    http://www.gamedev.net/blog/950/entry-2249317-a-guide-to-getting-started-with-boostasio?pg=4 本章节为io_ ...

随机推荐

  1. “数据上帝” Jeff Hammerbacher

    出生于1983年的数学天才Jeff Hammerbacher在23岁时加入了Facebook,一手组建起数据分析队伍.他是“数据科学”(data science)一词的提出者之一,被人们称为“数据上帝 ...

  2. set_false_path的用法

    set_false_path的用法 非功能性路径,因为两个多路选择器被相同的选择信号驱动? 上电复位信号 set_false两个异步时钟域的路径 在两个时钟域之间,设置set_false_path,应 ...

  3. Kafka 配置安装

    1.从官网下载安装包 http://kafka.apache.org/downloads2.上传到01虚拟机,解压3.进入安装目录下的config目录4.对server.properties进行配置 ...

  4. pytorch学习资料链接

    2017年12月25日15:06:44 官方文档:http://pytorch.org/docs/master/index.html 官方文档中文翻译:https://pytorch-cn.readt ...

  5. dubbo文档

    Srping版Dubbo集成中文地址: https://dubbo.gitbooks.io/dubbo-user-book/content/preface/background.html Spring ...

  6. Dubbo基本原理机制

      分布式服务框架: –高性能和透明化的RPC远程服务调用方案 –SOA服务治理方案 -Apache MINA 框架基于Reactor模型通信框架,基于tcp长连接 Dubbo缺省协议采用单一长连接和 ...

  7. android 开发 View _9_ 实现渐变功能(直线与圆形)

    参考博客:https://blog.csdn.net/iispring/article/details/50500106/ android颜色渐变的分类有: LinearGradient线性渐变 线性 ...

  8. linux 查看端口被占用

    linux 查看端口被占用 1.lsof  -i : 端口号 用于查看某一端口的占用情况,比如查看8080端口使用情况,lsof  -i:8080 如果执行 lsof  -i:8080 系统提示 :  ...

  9. 代码: !AJAX

    http://www.cnblogs.com/cwp-bg/p/7668840.html ajax和jsonp使用总结 2017-10-17 var requestUrl="http://l ...

  10. Innodb锁相关总结

    一.InnoDB共有七种类型的锁: (1)共享/排它锁(Shared and Exclusive Locks) (2)意向锁(Intention Locks) (3)插入意向锁(Insert Inte ...