1. 概述
最近项目中经常用到 asio 库的定时器,这里记录一下应用流程,以备查询。
2. 使用流程
2.1 定义以及初始化
定时器的定义:
boost::asio::steady_timer request_keyframe_timer_;
一般在类的构造函数初始化定时器,因为 asio::steady_timer
没有默认的构造函数,必须在构造时传入 asio::io_service
实例。
KeyframeRecover::KeyframeRecover(boost::asio::io_service& io_service)
: socket_(io_service),
strand_(io_service),
request_keyframe_timer_(io_service) {}
2.2 定义定时器超时处理函数
void KeyframeRecover::RequestTimerHandler() {
if (request_keyframe_timer_.expires_at() <= boost::asio::steady_timer::clock_type::now()) {
should_send_request_now_ = true;
}
}
2.3 设置超时时间并等待
bool KeyframeRecover::TrySendKeyframeRequest() {
if (!should_send_request_now_) {
return false;
}
CommonHeader header(1, PacketMessageType::RequestKeyframeType, 0);
boost::system::error_code ec;
for (auto i = 0; i < kMaxTimesToSendKeyframeRequest; ++i) {
socket_.send(boost::asio::buffer(&header, sizeof(CommonHeader)), 0, ec);
if (ec) {
LOG_ERROR << "Write error: " << ec;
return false;
}
}
LOG_INFO << "Keyframe request has been sent.";
// To avoid sending keyframe request too frequently.
request_keyframe_timer_.expires_from_now(std::chrono::milliseconds(200));
request_keyframe_timer_.async_wait(boost::bind(&KeyframeRecover::RequestTimerHandler, this));
should_send_request_now_ = false;
return true;
}
3. 小结
asio 库的定时器使用起来非常方便,在项目中使用也非常广泛,目前对 asio 库了解的还比较基础,今后还需要多看看 asio 库代码,发现更多好用的东西。