Boost.Asio:我可以取消在辅助线程中运行的SYNCHRONOUS操作吗?

时间:2015-07-17 10:07:57

标签: c++ multithreading networking boost boost-asio

我正在使用Boost.Asio和Boost.Thread。如何取消辅助线程中的同步IO操作? 例如,

/* consider needed headers included and typedefs are defined */

void OperationThread(sock_ptr sock) {
  char buf[128];
  boost::system::error_code ec;
  boost::asio::read(*sock, boost::asio::buffer(buf, 128), ec);
}

void AcceptorThread() {
  boost::asio::io_service serv;
  boost_asio_endpoint_type ep( ... /* v4() etc. */ , ... /* port */ );
  boost_asio_acceptor_type acc(serv, ep);
  sock_ptr sock(new boost_asio_socket_type(serv));
  while (true) {
    acc.accept(*sock);
    boost::thread t(boost::bind(&OperationThread, sock)); // new thread
    sock.reset(new boost_asio_socket_type(serv)); // new socket
  }
}

int main() {
  boost::thread accthread(&AcceptorThread);
  cin.get();
  // Code to cancel synchronous accept operation and read operations
  return 0;
}

sock_ptrboost::shared_ptr<boost_asio_socket_type>的typedef。

如果您对boost_asio_*_type感到困惑,请考虑将其配置为boost::asip::ip::tcpv4()

首先,我曾经使用过异步操作。但是你知道他们有点难以管理。我想要一个每线程一个线程的应用程序模型。使用异步IO实现它更难(实际上我不知道如何实现它,如何在线程中轮询特定的异步操作?如果你提到我会很高兴。)。所以我使用同步IO。

在我的代码中,正如您所注意到的,我的线程对象在while块结束时被销毁。它有害吗? (对不起,我知道在这个问题上提出这个问题是不合适的,但是任何想做我想做的事情的人都可能面对这个问题。所以如果你回答,我会非常高兴。ʘ‿ʘ)

感谢。

1 个答案:

答案 0 :(得分:0)

是的,您可以,只要您预先同步对服务对象的访问权限(例如boost::asio::ip::tcp::socketboost::asio::deadline_timer)¹。

另外,在您的代码中,您将使用来自不同线程的shared_ptr<>。共享指针不是线程安全的本身。虽然您可以使用the atomic_load and atomic_store functions来使其成为线程安全的。

¹文档揭示了对象是线程安全的(例外)情况。我记忆中只有两个是boost::asio::io_serviceboost::asio::strand