我正在尝试将一些旧代码从使用io_service迁移到基本tcp接受器的io_context,但是将get_io_service()切换到get_executor()时遇到了问题。context()导致以下错误:
cannot convert ‘boost::asio::execution_context’ to ‘boost::asio::io_context&’
这是侦听器:ImageServerListener::ImageServerListener(boost::asio::io_context& io)
{
_acceptor = new boost::asio::ip::tcp::acceptor(io, boost::asio::ip::tcp::endpoint(boost::asio::ip::tcp::v4(), sConfig.net.imageServerPort));
StartAccept();
}
ImageServerListener::~ImageServerListener()
{
delete _acceptor;
}
void ImageServerListener::StartAccept()
{
std::shared_ptr<ImageServerConnection> connection = ImageServerConnection::create(_acceptor->get_executor().context());
_acceptor->async_accept(connection->socket(), std::bind(&ImageServerListener::HandleAccept, this, connection));
}
void ImageServerListener::HandleAccept(std::shared_ptr<ImageServerConnection> connection)
{
connection->Process();
StartAccept();
}
为了返回io_context而不是execute_context,必须进行哪些更改? 最佳答案
您将需要关注执行者而不是上下文。
与上下文相比,传递执行者便宜,可以复制。
而且,它抽象出了(多态性)执行器附加到的执行上下文的类型,因此您无需打扰。
但是,执行程序的静态类型不是固定的。这意味着接受模板的典型方式是通过模板参数:
struct MyThing {
template <typename Executor>
explicit MyThing(Executor ex)
: m_socket(ex)
{ }
void do_stuff(std::string caption) {
post(m_socket.get_executor(),
[=] { std::cout << ("Doing stuff " + caption + "\n") << std::flush; });
}
// ...
private:
tcp::socket m_socket;
};
现在,您可以通过多种方式使用它,而无需进行更改:Live On Coliru
int main() {
boost::asio::thread_pool pool;
MyThing a(pool.get_executor());
MyThing b(make_strand(pool));
a.do_stuff("Pool a");
b.do_stuff("Pool b");
boost::asio::io_context ioc;
MyThing c(ioc.get_executor());
MyThing d(make_strand(ioc));
c.do_stuff("IO c");
d.do_stuff("IO d");
pool.join();
ioc.run();
}
这将打印类似Doing stuff Pool a
Doing stuff Pool b
Doing stuff IO c
Doing stuff IO d
类型擦除您可能已经猜到了,
m_socket
中存储了执行程序的类型擦除。如果您想这样做,可以使用boost::asio::any_io_executor ex;
ex = m_socket.get_executor();
关于c++ - Boost 1.70 io_service弃用,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/64776833/