[16 使用C++11开发一个简单的通信程序(Proactor模式)] 16.3 asio的基本用法

本文主要是介绍[16 使用C++11开发一个简单的通信程序(Proactor模式)] 16.3 asio的基本用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

asio的异步操作过程如下:(asio的全称为Asynchronous input and output(异步输入输出)的缩写)

图16-7 asio的异步操作过程

(1)应用程序发起了一个异步请求(异步读或写),需要提供socket或异步操作完成函数。

(2)asio的io_object对象会将这个异步请求交给操作系统,由操作系统完成该请求。

(3)调用io-service::run等待异步事件的完成。

(4)操作系统完成异步操作后,将异步操作的结果返回给io_service。

(5)io_service将完成事件的结果回调到对应的完成函数并处理。

用户要发起一个异步操作需要做如下3件事:

(1)发起异步操作,如async_read,async_write,async_connect,这些异步接口需要一个回调函数。

(2)调用io_service::run处理异步事件,必须保证io_service::run不退出,因为io_service通过一个循环去处理这些异步操作事件。一个简单办法是使用io_service::work,保证io_service一直运行。

(3)处理异步操作完成事件,回调函数处理。

16.3.1 异步connect

async_connect的基本用法:

asio::io_service io_service;
// 创建socket
aiso::ip::tcp::socket socket(io_service);
// 发起异步连接
boost::asio::async_connect(socket, server_address, connect_handler);
// 启动事件循环
io_service.run();

connect_handler的简单实现如下:

void connect_handler(const boost::system::error_code& error)
{if (error) {cout << error.message() << endl;// 异常处理return;}// do sth.
}

16.3.2 异步read

async_read和async_write需要一个boost::asio::buffer来作为数据读和写的缓冲区。

async_read的基本用法如下:

asio::io_service io_service;
asio::ip:tcp::socket socket(io_service);
std::string str = "test";
boost::asio::async_read(socket, boost::asio::buffer(str.c_str(), str.length()+1), read_handler);
io_service.run();void read_handler(const boost::system::error_code& error)
{if (error) {cout << error.message() << endl;// 异常处理return;}// do sth.
}

16.3.3 异步write

注意:不能连续调用异步发送接口async_write。

async_write内部不断调用async_write_some,直到所有的数据发送完成为止。如果第一次调用async_write发送一个较大的包,马上又再调用async_write发送一个很小的包。很可能第二个包先发完,第一个包还没发完,导致乱序问题。解决办法是用发送缓冲区控制发送。

异步发送的示例如下:

// 发送队列
std::list<Message> m_sendQueue;void AsyncWrite()
{auto msg = m_sendQueue.front();async_write(m_sock, buffer(msg.pData, msg.len), boost::bind(&HandleWrite, boost::asio::placeholders:error));
}void HandleWrite(boost:system::error_code& ec)
{if (!ec) {m_sendQueue.pop_front();if (!m_sendQueue.empty()) {AsyncWrite();}} else {HandleError(ec);if (!m_sendQueue.empty()) {m_sendQueue.clear();}}
}

注意:发送数据(AsyncWrite)和io_service.run()必须在同一个线程里执行。

这篇关于[16 使用C++11开发一个简单的通信程序(Proactor模式)] 16.3 asio的基本用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1093721

相关文章

Pandas使用SQLite3实战

《Pandas使用SQLite3实战》本文主要介绍了Pandas使用SQLite3实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1 环境准备2 从 SQLite3VlfrWQzgt 读取数据到 DataFrame基础用法:读

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

Java中StopWatch的使用示例详解

《Java中StopWatch的使用示例详解》stopWatch是org.springframework.util包下的一个工具类,使用它可直观的输出代码执行耗时,以及执行时间百分比,这篇文章主要介绍... 目录stopWatch 是org.springframework.util 包下的一个工具类,使用它

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

springboot security使用jwt认证方式

《springbootsecurity使用jwt认证方式》:本文主要介绍springbootsecurity使用jwt认证方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录前言代码示例依赖定义mapper定义用户信息的实体beansecurity相关的类提供登录接口测试提供一

go中空接口的具体使用

《go中空接口的具体使用》空接口是一种特殊的接口类型,它不包含任何方法,本文主要介绍了go中空接口的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录接口-空接口1. 什么是空接口?2. 如何使用空接口?第一,第二,第三,3. 空接口几个要注意的坑坑1:坑2:坑3:接口-空接口1. 什么是空接

springboot security快速使用示例详解

《springbootsecurity快速使用示例详解》:本文主要介绍springbootsecurity快速使用示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录创www.chinasem.cn建spring boot项目生成脚手架配置依赖接口示例代码项目结构启用s

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为