我正在使用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_ptr
是boost::shared_ptr<boost_asio_socket_type>
的typedef。
如果您对boost_asio_*_type
感到困惑,请考虑将其配置为boost::asip::ip::tcp
和v4()
。
首先,我曾经使用过异步操作。但是你知道他们有点难以管理。我想要一个每线程一个线程的应用程序模型。使用异步IO实现它更难(实际上我不知道如何实现它,如何在线程中轮询特定的异步操作?如果你提到我会很高兴。)。所以我使用同步IO。
在我的代码中,正如您所注意到的,我的线程对象在while块结束时被销毁。它有害吗? (对不起,我知道在这个问题上提出这个问题是不合适的,但是任何想做我想做的事情的人都可能面对这个问题。所以如果你回答,我会非常高兴。ʘ‿ʘ)
感谢。
答案 0 :(得分:0)
是的,您可以,只要您预先同步对服务对象的访问权限(例如boost::asio::ip::tcp::socket
或boost::asio::deadline_timer
)¹。
另外,在您的代码中,您将使用来自不同线程的shared_ptr<>
。共享指针不是线程安全的本身。虽然您可以使用the atomic_load
and atomic_store
functions来使其成为线程安全的。
¹文档揭示了对象是线程安全的(例外)情况。我记忆中只有两个是boost::asio::io_service
和boost::asio::strand