委托使用boost asio TCP / IP套接字

时间:2019-02-13 12:52:03

标签: c++ sockets tcp boost-asio

我创建了一个具有boost asio tcp套接字并进行异步读取的TCP客户端:

class TCPClient {
 public:
  TCPClient(boost::asio::io_service& io_service)
    : socket_(io_service) {
    // Connect
    [...]
    // Asynchronous read
    socket_.async_read_some(boost::asio::buffer(buffer, buffer.size()),
                            boost::bind(&TCPClient::handlerRead,
                                        this,
                                        placeholders::error,
                                        placeholders::bytes_transferred));
  }
  ~TCPClient() {}

  void handlerRead(const boost::system::error_code& ec, uint32_t bytes) {
    if (!ec) {
      // process
      [...]
      socket_.async_read_some(
        boost::asio::buffer(buffer, buffer.size()),
        boost::bind(&TCPClient::handlerRead,
                    this,
                    placeholders::error,
                    placeholders::bytes_transferred));
  }

  int getSocketFd() {
    return socket_.native_handle();
  }

 private:
  boost::asio::tcp::socket socket_;
};

这很好。 但是当我将其放入线程中时:

boost::asio::io_service io_service;
auto client = new TCPClient(io_service);
std::thread{[&io_service](){ io_service.run(); }};

...并获取套接字的文件描述符:

int socket_fd = client->getSocketFd();

因为我希望程序的这一部分使用TCP / IP套接字在此套接字上发送数据包。 但是然后,我的程序出现以下错误:

#1  0x000000000041fab0 in boost::asio::detail::task_io_service_operation::complete(boost::asio::detail::task_io_service&, boost::system::error_code const&, unsigned long) ()
#2  0x0000000000420b5f in boost::asio::detail::task_io_service::do_run_one(boost::asio::detail::scoped_lock<boost::asio::detail::posix_mutex>&, boost::asio::detail::task_io_service_thread_info&, boost::system::error_code const&) ()
#3  0x00000000004207df in boost::asio::detail::task_io_service::run(boost::system::error_code&) ()
#4  0x0000000000420eab in boost::asio::io_service::run() ()

您对这里发生的事情有任何线索吗?

1 个答案:

答案 0 :(得分:1)

您可以在一个线程中在堆栈上定义io_service。但是您可以从其他线程访问它。似乎在.run()调用时该对象不再存在。

将其移动到堆是一种可能。无论如何,都需要对代码,组件与活动性之间的关系进行更深入的分析。