Asio异步编程核心是“不等结果、先干别的”,依赖回调或协程驱动;Standalone版免Boost依赖,API与Boost.Asio一致;TCP客户端需管理socket/缓冲区生命周期,服务器用session封装连接,协程需C++20支持且返回awaitable类型。
用 Asio 做异步编程,核心是“不等结果、先干别的”,靠回调或协程驱动后续逻辑。Boost.Asio 和 Standalone Asio(即 asio 单头文件版)API 几乎一致,区别只在编译方式和依赖——Standalone 版无需 Boost 库,头文件包含即可用;Boost.Asio 需链接 boost_system(Windows 下还常要 ws2_32)。实战中选哪个取决于项目约束,功能上没差别。
典型流程:创建 socket → 异步 connect → 成功后 async_write → 再 async_read。所有操作都传入一个可调用对象(lambda、function 或绑定函数),作为完成时的回调。
io_context.run() 或 io_context.run_one() 驱动)std::vector 或 std::array 配合 asio::buffer()
服务器模式常用“accept → 创建新 session → 继续 accept”循环。每个客户端连接应封装为独立对象(如 session 类),持有 socket、缓冲区、io_context 引用,并负责自身生命周期管理。
async_accept(),成功后把新 socket 移交给 session 对象async_read(),读到数据后处理、再发 async_write(),最后通常继续 async_read() 形成循环shared_from_this()(需继承 std::enable_shared_from_this)保证对象存活
_awaitable)Asio 从 1.70+ 原生支持 C++20 协程(需编译器开启 /std:c++20 或 -std=c++20),用 co_await 替代回调,代码线性易读。
asio::awaitable,且在 io_context 的协程调度器中启动(如 co_spawn(io_ctx, my_handler(), asio::detached))co_await socket.async_connect(..., asio::use_awaitable) 形式system_error 抛出,可用 try/catch 捕获,比手动检查 error_code 更直观异步编程容易因资源管理或执行顺序出错,以下几点高频踩坑:
io_context::work 防止提前结束post() 或 dispatch() 把任务安全投递到其执行上下文ASIO_ENABLE_HANDLER_TRACKING 宏)能清晰看到每个操作的触发与完成链路基本上就这些。Standalone Asio 编译更轻量,Boost.Asio 生态更成熟;协程写法清爽但要求较新工具链;回调风格兼容性强,适合嵌入式或长期维护项目。选型看团队习惯和平台限制,底层机制是一样的。