0

0

c++如何使用Asio库进行异步网络编程_c++非阻塞IO模型

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-02 15:10:02

|

150人浏览过

|

来源于php中文网

原创

Asio库通过io_context实现异步非阻塞IO,核心组件包括io_context、socket和async_*函数;示例展示异步TCP服务器使用shared_from_this管理生命周期,以回调处理读写,io_context.run()驱动事件循环,客户端同理需调用run();关键点为保持io_context运行、正确管理对象生命周期、避免回调抛异常,可多线程调用run()提升性能,适用于高并发网络服务。

c++如何使用asio库进行异步网络编程_c++非阻塞io模型

在C++中使用Asio库进行异步网络编程,可以高效实现非阻塞IO模型,适用于高并发的网络服务开发。Asio(Asynchronous Input/Output)是一个跨平台的C++库,用于网络和低层IO编程,它支持同步和异步操作,而异步模式正是实现高性能服务器的核心。

理解Asio中的异步模型

Asio通过事件循环(io_context)来管理异步操作。所有异步任务都注册到io_context中,当某个IO事件就绪(如数据到达、连接完成),对应的回调函数会被调用。

异步操作不会阻塞调用线程,程序可以在等待IO期间执行其他任务,这正是非阻塞IO的关键所在。

核心组件包括:

立即学习C++免费学习笔记(深入)”;

  • io_context:事件循环,负责调度和执行异步操作
  • socket:代表网络连接,如tcp::socket
  • async_* 系列函数:发起异步操作,如 async_read, async_write, async_accept
  • 回调函数(handler):操作完成时被调用,处理结果

编写一个异步TCP服务器示例

以下是一个简单的异步回显服务器,展示如何使用Asio进行非阻塞编程:

Amazon Nova
Amazon Nova

亚马逊云科技(AWS)推出的一系列生成式AI基础模型

下载
#include 
#include 
#include 

using asio::ip::tcp;

class session : public std::enable_shared_from_this
{
public:
    session(tcp::socket socket) : socket_(std::move(socket)) {}

    void start()
    {
        do_read();
    }

private:
    void do_read()
    {
        auto self(shared_from_this());
        socket_.async_read_some(asio::buffer(data_),
            [this, self](std::error_code ec, std::size_t length)
            {
                if (!ec)
                    do_write(length);
            });
    }

    void do_write(std::size_t length)
    {
        auto self(shared_from_this());
        asio::async_write(socket_, asio::buffer(data_, length),
            [this, self](std::error_code ec, std::size_t /*length*/)
            {
                if (!ec)
                    do_read(); // 继续读取
            });
    }

    tcp::socket socket_;
    char data_[1024];
};

class server
{
public:
    server(asio::io_context& io_context, short port)
        : acceptor_(io_context, tcp::endpoint(tcp::v4(), port))
    {
        do_accept();
    }

private:
    void do_accept()
    {
        acceptor_.async_accept(
            [this](std::error_code ec, tcp::socket socket)
            {
                if (!ec)
                {
                    std::make_shared(std::move(socket))->start();
                }
                do_accept(); // 接受下一个连接
            });
    }

    tcp::acceptor acceptor_;
};

int main()
{
    try
    {
        asio::io_context io_context;
        server s(io_context, 8080);
        io_context.run(); // 启动事件循环
    }
    catch (std::exception& e)
    {
        std::cerr << "Exception: " << e.what() << "\n";
    }
    return 0;
}

这个例子展示了Asio异步编程的基本结构:

  • 使用 shared_from_this 管理会话生命周期,避免对象提前析构
  • 每个异步操作传入 lambda 作为回调,处理完成后的逻辑
  • 通过递归调用 do_readdo_accept 实现持续服务
  • io_context.run() 阻塞并运行事件循环,直到无任务为止

异步客户端的简单实现

客户端同样可以使用异步方式连接和通信:

void start_client()
{
    asio::io_context io_context;
    tcp::socket socket(io_context);

    socket.async_connect(tcp::endpoint(asio::ip::address::from_string("127.0.0.1"), 8080),
        [&socket](std::error_code ec)
        {
            if (!ec)
            {
                std::string msg = "Hello\n";
                asio::async_write(socket, asio::buffer(msg),
                    [](std::error_code ec, std::size_t length)
                    {
                        // 发送完成
                    });
            }
        });

    io_context.run();
}

注意:客户端也需要调用 io_context.run() 来驱动异步操作。

关键注意事项

使用Asio进行异步编程时,有几个要点必须掌握:

  • 确保 io_context 在异步操作期间持续运行,否则回调不会被执行
  • 正确管理对象生命周期,特别是使用 shared_ptr 配合 shared_from_this
  • 避免在回调中抛出异常,应通过 error_code 处理错误
  • 可使用多个线程调用 io_context::run() 提升性能
  • 对于定时任务,可使用 asio::steady_timer 实现异步延时操作
基本上就这些。Asio的异步模型虽然初看复杂,但一旦理解了事件循环和回调机制,就能写出高效稳定的网络程序。非阻塞IO的优势在于能用少量线程处理大量连接,适合现代高并发场景。

相关专题

更多
lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

202

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

189

2025.11.08

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

473

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

131

2025.12.24

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

180

2023.11.24

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

45

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

40

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

41

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 2.7万人学习

Excel 教程
Excel 教程

共162课时 | 10.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号