C++ 为什么多个boost::io_服务会阻塞主线程?
我有一个应用程序,需要从7个串行端口读取。我创建了一个类来封装串行端口,打开boost::asio::Serial_端口并启动异步读取操作。我正在接收我的所有数据,但是io_服务线程占用了大量CPU时间并减慢了我的主线程。有没有办法阻止io_服务线程使用如此多的CPU时间?一些伪代码:C++ 为什么多个boost::io_服务会阻塞主线程?,c++,boost,C++,Boost,我有一个应用程序,需要从7个串行端口读取。我创建了一个类来封装串行端口,打开boost::asio::Serial_端口并启动异步读取操作。我正在接收我的所有数据,但是io_服务线程占用了大量CPU时间并减慢了我的主线程。有没有办法阻止io_服务线程使用如此多的CPU时间?一些伪代码: construct io_service for each port open port start async read ( register read_handler_for_port ) run
construct io_service
for each port
open port
start async read ( register read_handler_for_port )
run io_service
read_handler_for_port ()
handle data
start async read ( register read_handler_for_port )
请在您的问题中包含一个演示问题的示例。您的问题标题表明您有多个io::服务。那太糟糕了!“你只需要一个。”我需要。每个串行端口类都有自己的io_服务。我是否应该创建一个静态端口并将每个端口分配给它?您应该只使用一个端口。不知道静态是什么意思。例如,我有一个应用程序,使用一个io_服务读取两个端口并写入四个端口。io服务会根据需要管理每个端口。感谢您帮助我解决了问题。有点打嗝就可以了,但我现在正在想办法。