安全地取消Boost Asio Deadline Timer
本文解決了boost::asio::basic_waitable_timer<:chrono: :steady_clock>
問題:
最初,建議的解決方案是透過timer.get_io_service().post([&]{timer.cancel()取消計時器;}) 可能會失敗。即使呼叫cancel()後,計時器也不會中止。
原因:
問題在於計時器取消後的行為。它不會終止未完成的非同步操作,只是在呼叫完成處理程序時啟動新的非同步等待。
解決方案:
要安全地取消計時器,必須檢查目前是否有任何非同步操作正在進行中。可以透過比較計時器的到期時間與當前時間來執行此檢查:
<code class="cpp">timer.get_io_service().post([](){ if (timer.expires_from_now() >= std::chrono::steady_clock::duration(0)) { timer.cancel(); } });</code>
增強取消:
除了取消當前操作外,還可以向完成處理程序傳達關閉訊號是有益的。這可以透過將計時器的到期時間設為特殊值來實現,例如 Timer::clock_type::time_point::min()。
<code class="cpp">timer.expires_at(Timer::clock_type::time_point::min());</code>
這允許完成處理程序識別關閉狀態:
<code class="cpp">void handle_timeout(const boost::system::error_code& ec) { if (timer.expires_at() != Timer::time_point::min()) { // timer is not in shutdown state // ... } else { // timer is in shutdown state std::cerr << "handle_timeout: detected shutdown\n"; } }</code>
透過實現這些技術,可以取消boost::asio::basic_waitable_timer<:chrono::steady_clock> 。計時器變得既安全又強大。
以上是如何安全取消 boost::asio::basic_waitable_timer?的詳細內容。更多資訊請關注PHP中文網其他相關文章!