热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用boost::asio实现高效异步TCP编程

本文介绍了如何利用`boost::asio`库实现高效的异步TCP编程。与传统的同步方式不同,异步编程允许程序在发起I/O操作后立即返回,继续执行其他任务,从而显著提高系统的响应速度和整体性能。通过具体的代码示例和详细解释,本文展示了如何在实际应用中充分利用`boost::asio`的强大功能,实现高效、可靠的网络通信。

大家好,我是异步方式

和同步方式不同,我从来不花时间去等那些龟速的IO操作,我只是向系统说一声要做什么,然后就可以做其它事去了。如果系统完成了操作, 系统就会通过我之前给它的回调对象来通知我。

在ASIO库中,异步方式的函数或方法名称前面都有“async_ ” 前缀,函数参数里会要求放一个回调函数(或仿函数)。异步操作执行 后不管有没有完成都会立即返回,这时可以做一些其它事,直到回调函数(或仿函数)被调用,说明异步操作已经完成。

在ASIO中很多回调函数都只接受一个boost::system::error_code参数,在实际使用时肯定是不够的,所以一般 使用仿函数携带一堆相关数据作为回调,或者使用boost::bind来绑定一堆数据。

另外要注意的是,只有io_service类的run()方法运行之后回调对象才会被调用,否则即使系统已经完成了异步操作也不会有任 务动作。

好了,就介绍到这里,下面是我带来的异步方式TCP Helloworld服务器端:

// BoostTcpServer.cpp : 定义控制台应用程序的入口点。
//#include "stdafx.h"
#include "boost/asio.hpp"
#include "boost/shared_ptr.hpp"
#include "boost/thread.hpp"using namespace std;
using namespace boost::asio;#ifdef _MSC_VER
#define _WIN32_WINNT 0X0501 //避免VC下编译警告
#endif#define PORT 1000
#define IPV6
//#define IPV4class AsyncServer
{
public://构造函数AsyncServer(io_service &io,ip::tcp::endpoint &ep):ios(io),acceptor(io,ep){//acceptor(ios,ep);start();}//启动异步接受客户端连接void start(){sock_ptr sock(new ip::tcp::socket(ios));//当有连接进入时回调accept_handler函数acceptor.async_accept(*sock,boost::bind(&AsyncServer::accept_handler,this,placeholders::error,sock));}
private:io_service &ios;ip::tcp::acceptor acceptor;typedef boost::shared_ptr sock_ptr;void accept_handler(const boost::system::error_code &ec, sock_ptr sock){if(ec) return;//输出客户端连接信息std::cout <<"remote ip:"<remote_endpoint().address()<remote_endpoint().port() <async_write_some(buffer("I heard you!"),bind(&AsyncServer::write_handler,this,placeholders::error));//再次启动异步接受连接start();}void write_handler(const boost::system::error_code&){cout<<"send msg complete!"<};int _tmain(int argc, _TCHAR* argv[])
{try{//定义io_service对象io_service ios;//定义服务端endpoint对象(协议和监听端口)
#ifdef IPV4ip::tcp::endpoint serverep(ip::tcp::v4(),PORT);
#endif#ifdef IPV6ip::tcp::endpoint serverep(ip::tcp::v6(),PORT);
#endif//启动异步服务AsyncServer server(ios, serverep);//等待异步完成ios.run();}catch (std::exception& e){cout<}

客户端一般无需采用异步方式&#xff0c;同同步方式即可。


推荐阅读
  • 一键将应用部署至远程服务器,体验超乎想象的便捷与高效
    该插件作为IDEA的内置功能,用户可以直接启用,无需额外安装。通过简单的配置,即可实现应用的一键部署至远程服务器,极大地提升了开发效率和便捷性。插件支持镜像管理和容器管理,允许用户与容器进行交互,并且兼容Docker Compose,适用于复杂的多容器应用部署。总结部分详细介绍了插件的使用方法和优势,附带的参考资料和项目源码地址为用户提供更多学习和实践资源。 ... [详细]
  • 本文介绍了一个基于C++标准库实现的INI文件读写操作类。该类在现有网络资源的基础上进行了扩展和优化,增加了获取当前可执行文件路径和宽字节与多字节字符串转换的功能。通过这些增强功能,该类能够更好地适应各种应用场景,提高代码的可移植性和健壮性。具体实现细节请参见 `IniFileSTL.h` 文件。 ... [详细]
  • 内网渗透技术详解:PTH、PTT与PTK在域控环境中的应用及猫盘内网穿透配置
    本文深入探讨了内网渗透技术,特别是PTH、PTT与PTK在域控环境中的应用,并详细介绍了猫盘内网穿透的配置方法。通过这些技术,安全研究人员可以更有效地进行内网渗透测试,解决常见的渗透测试难题。此外,文章还提供了实用的配置示例和操作步骤,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 程序连接MySQL数据库的多种方法详解 ... [详细]
  • PAT甲级 1068 寻找更多硬币 (30分) 01背包问题与路径优化
    PAT甲级 1068 寻找更多硬币 (30分) 01背包问题与路径优化 ... [详细]
  • 如何在C++中定位数组中特定数字的最后一个位置 ... [详细]
  • 安装Qt时,Qt\Qt5.x.x文件夹下自动安装了example文件夹,其中包含了大量的示例。这里根据Examples\Qt-5.5\widgets\t ... [详细]
  • c语言中阶乘的精确值
     对于大数的操作,可能超出int,甚至long的表示范围,对此,可以使用数组来存储大数,下列代码为求1000以内数的阶乘的代码,代码如下:#include&amp;amp; ... [详细]
  • 幻方是一种独特的数学结构,由1至N×N的数字组成N×N的矩阵,其中每一行、每一列以及两条对角线上的数字之和均相等。对于奇数阶的幻方,可以通过特定的方法进行构建。首先,将数字1放置在第一行的中间位置,然后按照一定的规则逐步填充其余数字,最终形成一个完美的幻方。这种构造方法不仅展示了数学的美妙,还为研究者提供了一个探索数字排列规律的独特视角。 ... [详细]
  • 在解决此问题时,最初对输入格式的理解存在困惑,导致编写代码过程中出现多次错误。通过参考他人代码,最终明白输入包含两个测试案例:一个案例中有4个节点,需要进行两次结构对比;另一个案例有2个节点,只需进行一次对比。输出结果应为“是”或“否”,以表明两棵树的结构是否相同。 ... [详细]
  • 本文详细介绍了在 CentOS 6.7 x64 环境下配置 MySQL 5.6.29 的 GTID 主从复制方法。主库 IP 为 192.168.0.65,备库 IP 为 192.168.0.66。通过逐步指导,帮助读者顺利实现高可用性和数据一致性。 ... [详细]
  • 图像拼接技术深入解析:基于OpenCV 3.4的Stitching模块源码分析(下篇)
    本文继续深入探讨图像拼接技术,特别是在OpenCV 3.4的Stitching模块中的源码实现。通过与VLFeat的SIFT实现进行对比,详细分析了OpenCV在图像特征提取、匹配及拼接过程中的关键算法和技术细节,为读者提供了全面的技术解析和实践指导。 ... [详细]
  • 分析: 首先判断线段俩直线是否平行(或重合),如果是的话直接求。考虑4个端点到另外一条线段的距离,取最小值即可 ... [详细]
  • 这个题手动压位非常麻烦,因为对于同一块,后加的数比先加的数小,所以判断最后一位的时候需要定位到最后一块最小的数,而且在找元的时候还不能找到这个位置注意块的总数每个是30个不要存错, ... [详细]
  • CatchThatCowTimeLimit:50002000MS(JavaOthers)MemoryLimit:3276832768K(JavaOt ... [详细]
author-avatar
手机用户2602886175
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有