c – 重置线程的休眠时间
发布时间:2020-12-16 07:08:07 所属栏目:百科 来源:网络整理
导读:假设有一个像这样的线程 void mythread(){ int res; while(1) { { boost::lock_guardboost::mutex lock(mylock); res = do_my_stuff(); } boost::this_thread::sleep(boost::posix_time::seconds(5)); }} 而且线程正在休眠.如果在线程之外发生了某些事情,我
假设有一个像这样的线程
void mythread() { int res; while(1) { { boost::lock_guard<boost::mutex> lock(mylock); res = do_my_stuff(); } boost::this_thread::sleep(boost::posix_time::seconds(5)); } } 而且线程正在休眠.如果在线程之外发生了某些事情,我希望能够增加睡眠时间. 最好的方法是什么? 解决方法
使用condition_variable发出更改截止日期的信号
这有利于支持缩短超时的方案: 见它Live On Coliru #include <thread> #include <chrono> #include <iostream> #include <condition_variable> namespace demo { namespace chrono = std::chrono; using our_clock = chrono::system_clock; struct Worker { mutable std::mutex _mx; // shared,protected by _mx: our_clock::time_point _deadline; mutable std::condition_variable _cv; Worker(our_clock::time_point deadline) : _deadline(deadline) {} void operator()() const { std::unique_lock<std::mutex> lk(_mx); _cv.wait_until(lk,_deadline,[this] { std::cout << "worker: Signaledn"; auto now = our_clock::now(); if (now >= _deadline) return true; std::cout << "worker: Still waiting " << chrono::duration_cast<chrono::milliseconds>(_deadline - now).count() << "ms...n"; return false; }); std::cout << "worker: Donen"; } }; } int main() { using namespace demo; Worker worker(our_clock::now() + chrono::seconds(2)); auto th = std::thread(std::cref(worker)); // after 2 seconds,update the timepoint std::this_thread::sleep_for(chrono::seconds(1)); { std::lock_guard<std::mutex> lk(worker._mx); std::cout << "Updating shared delay value..." << "n"; worker._deadline = our_clock::now() + chrono::seconds(1); worker._cv.notify_all(); } th.join(); } C 11标准库(无信令) 这是一种仅限标准库的方法,在截止日期前不使用同步. 我更倾向于使用原子time_point作为截止时间值本身,但这不受支持.接下来最好的事情就是shared_ptr< time_point> (使用std :: atomic_load / atomic_store)但我的编译器库尚未实现(grrr). 所以,相反,我从开始时间开始分享’偏移’: #include <thread> #include <chrono> #include <iostream> #include <atomic> namespace demo { namespace chrono = std::chrono; using our_clock = chrono::system_clock; using shared_delay = std::atomic<our_clock::duration>; void worker(our_clock::time_point const start,shared_delay const& delay) { for (our_clock::time_point deadline; our_clock::now() < (deadline = start + delay.load());) { std::cout << "worker: Sleeping for " << chrono::duration_cast<chrono::milliseconds>(deadline - our_clock::now()).count() << "ms...n"; std::this_thread::sleep_until(deadline); } std::cout << "worker: Donen"; } } int main() { using namespace demo; shared_delay delay(chrono::seconds(2)); auto th = std::thread(worker,our_clock::now(),std::cref(delay)); // after 2 seconds,update the timepoint std::this_thread::sleep_for(chrono::seconds(1)); std::cout << "Updating shared delay value..." << "n"; delay.store(chrono::seconds(3)); th.join(); } 见它Live on Coliru (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |