在使用boost::asio套接字从网络中接收数据时,我们可能需要设置超时时间以确保操作不会无限期地阻塞。解决方法是使用基于时间的异步等待函数来实现超时读取。以下是一个示例代码:
#include
using boost::asio::ip::tcp;
class Session { public: Session(boost::asio::io_service& ios) : m_socket(ios), m_timer(ios) {}
tcp::socket& socket() { return m_socket; }
void start() { asyncRead(); }
private: void asyncRead() { m_socket.async_read_some(boost::asio::buffer(m_buffer), boost::bind(&Session::handleRead, this, boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred));
m_timer.expires_from_now(std::chrono::seconds(10));
m_timer.async_wait(boost::bind(&Session::handleTimeout, this));
}
void handleRead(const boost::system::error_code& error, std::size_t bytes_transferred) { m_timer.cancel();
if (error) {
std::cerr << "read error: " << error.message() << std::endl;
return;
}
std::cout << "read " << bytes_transferred << " bytes: ";
std::cout.write(m_buffer.data(), bytes_transferred);
std::cout << std::endl;
asyncRead();
}
void handleTimeout() { std::cerr << "read timeout" << std::endl; m_socket.cancel(); }
tcp::socket m_socket;
boost::asio::steady_timer m_timer;
std::array
int main() { try { boost::asio::io_service ios; tcp::acceptor acceptor(ios, tcp::endpoint(tcp::v4(), 12345));
while (true) {
std::cout << "waiting for connection..." << std::endl;
tcp::socket socket(ios);
acceptor.accept
上一篇:asynchronousmessagethreadusingZMQ
下一篇:AsynchronousrepliesinUMLsequencediagrams(async/awaitpattern)