gpt4 book ai didi

c++ - boost asio 在线程中运行 io_service

转载 作者:太空狗 更新时间:2023-10-29 21:15:47 26 4
gpt4 key购买 nike

我尝试使用 boost::asio 和 boost::thread 运行异步网络线程。但是 async_accept 立即返回错误代码 125 - 操作已取消......

附上问题的最小示例:

#include <iostream>
#include <boost/asio.hpp>
#include <boost/thread.hpp>

class Server{

public:
Server()
{ }

void listen(unsigned int port)
{
boost::asio::ip::tcp::endpoint endpoint(boost::asio::ip::tcp::v4(), port);
boost::asio::ip::tcp::acceptor acceptor(m_io_service, endpoint);

std::cout << "Waiting for incomming connection on port: " << port << std::endl;

acceptor.async_accept(*m_stream.rdbuf(), boost::bind( &Server::handleAccept, this, boost::asio::placeholders::error, boost::ref( acceptor ) ) );
m_listenThread = new boost::thread(boost::bind(&boost::asio::io_service::run, &m_io_service));

}

void stop()
{
m_listenThread->join();
}

private:

void handleAccept(const boost::system::error_code& error, boost::asio::ip::tcp::acceptor& acceptor)
{
std::cout << "receiverd incomming connection" << std::endl;
if(error)
std::cout << "ERROR: " << error.message() << "(" << error.value() << ")" << std::endl;

}

boost::asio::io_service m_io_service;
boost::asio::ip::tcp::iostream m_stream;
boost::thread* m_listenThread;


};



int main(int argc, char *argv[])
{
Server server;
server.listen(10000);

while(1);
}

最佳答案

acceptor::async_accept 立即返回,在出现错误或连接被接受时安排调用处理程序 (1)

listen() 函数正在返回,这导致了接受器 (2) 的破坏

当一个acceptor(或socket,或deadline_timer)被销毁时,所有挂起的处理程序都被调度到io_service 错误代码为 asio::error::operation_aborted。这是为了满足 async_ 函数的后置条件(即,“处理程序将恰好被调用一次,就像 io_service.post() 一样”)(3)

因此,在第 (2) 点,正在安排您的处理程序 - 就在代码返回主循环之前。

修复:

确保 acceptor 在处理程序被调用之前存在。这是 asio 异步编程中的标准做法。 boost 网站上的示例将帮助您理解(稀疏的)asio 文档。

不要失去希望。我花了很长时间才学会如何正确使用 asio,并意识到它有多么强大。

关于c++ - boost asio 在线程中运行 io_service,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36746483/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com