c++ - Boost asio 截止时间计时器立即完成(C++)
问题描述
下面的代码会立即打印“已连接”到控制台,而不是 10 秒后。为什么是这样?这与我传递print
回调的方式有关吗?
void print(const boost::system::error_code& e) {
std::cout << "connected!" << std::endl;
}
class WebSocketSession {
public:
WebSocketSession(asio::io_context &io_context) : io_context_(io_context) {}
void connect() {
boost::asio::deadline_timer
timer(io_context_, boost::posix_time::seconds(10));
timer.async_wait(&print);
}
private:
asio::io_context &io_context_;
};
class WebSocketClient {
public:
WebSocketClient(asio::io_context &io_context) : io_context_(io_context) {}
std::unique_ptr<WebSocketSession> exec() {
auto session = std::make_unique<WebSocketSession>(io_context_);
session->connect();
return session;
}
private:
asio::io_context &io_context_;
};
int main() {
asio::io_context io_context;
WebSocketClient client{io_context};
std::unique_ptr<WebSocketSession> session = client.exec();
io_context.run();
return 0;
}
解决方案
正如评论中提到的,deadline_timer
因为它是一个局部变量而过早地被销毁,从而取消了 I/O 操作。
如果我们添加一些错误处理,我们将看到报告的实际错误:
void print(const boost::system::error_code& e) {
if (e.failed())
std::cout << "error: " << e.message() << std::endl;
else
std::cout << "connected!" << std::endl;
}
印刷:
error: The I/O operation has been aborted because of either a thread exit or an application request
一个可能的解决方法是deadline_timer
成为以下成员WebSocketSession
:
class WebSocketSession {
public:
WebSocketSession(boost::asio::io_context& io_context) : io_context_(io_context),
timer_(io_context, boost::posix_time::seconds(10)) {}
void connect() {
timer_.async_wait(&print);
}
private:
boost::asio::io_context& io_context_;
boost::asio::deadline_timer timer_;
};
推荐阅读
- python - Google Colaboratory 本地主机中没有 tensorflow
- sql - PostgreSQL 获取带有物品的订单
- node.js - DynamoDB 数据模型
- c# - System.DLLNotFoundException 在 Mac 上使用 Xamarin
- java - JavaFX:添加元素的 ObservableArrayList 冻结应用程序
- angular - Angular 6 中包装组件的问题
- python - 用opencv计算多个区域
- angular - 父组件到子组件值的角度未正确传递
- ios - Xcode 10 无效的二进制架构?
- azure - 我们可以将应用服务限制在 Azure 中的特定国家/地区吗?