在多个线程上使用单个io_service的好处是什么?

Whats the benefit of using a single io_service over multiple threads?

本文关键字:service 是什么 io 单个 线程      更新时间:2023-10-16

我正在阅读一些关于Asio的答案和一个突出的模式,无论是在示例中还是在SO中,都是使用单个io_service并在worker之间共享它,这些worker将处理通过套接字打开,发送和接收消息。

在多个套接字抽象之间共享io_service有什么好处吗?为什么不让每个都有自己的io_service呢?

据我所知,io_service"拥有"该资源。如果你有一个io_service处理所有的asio函数,那么你可以管理优先级。如果你有多个io_service实例,它们都"拥有"相同的资源,那么它们就会发生冲突。

我尝试过这种模式,除了一些非常特殊的场景,我不建议您再使用它。相反,我建议使用"总是只从单个io_service使用套接字"的方法,并使用多个io_services(每个在一个专用线程中运行),如果你有需要的话。

这样做的原因是,如果你从多个线程中使用一个io_service,那么你所有的回调(完成处理程序)都可以从任何参与的线程中调用,你必须为它们提供额外的同步。在"资源属于在一个线程上执行的io_service"模型中,你不需要这个,因为没有并发处理程序将从另一个线程执行。