function
<thread>

std::this_thread::sleep_until

template <class Clock, class Duration> void sleep_until (const chrono::time_point<Clock,Duration>& abs_time);
Sleep until time point
Blocks the calling thread until abs_time.

The execution of the current thread is stopped until at least abs_time, while other threads may continue to advance.

Parameters

abs_time
A point in time when the calling thread shall resume its execution.
Note that multi-threading management operations may cause certain delays beyond this.
time_point is an object that represents a specific absolute time.

Return value

none

Example

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
// this_thread::sleep_for example
#include <iostream> // std::cout
#include <iomanip> // std::put_time
#include <thread> // std::this_thread::sleep_until
#include <chrono> // std::chrono::system_clock
#include <ctime> // std::time_t, std::tm, std::localtime, std::mktime
int main() 
{
 using std::chrono::system_clock;
 std::time_t tt = system_clock::to_time_t (system_clock::now());
 struct std::tm * ptm = std::localtime(&tt);
 std::cout << "Current time: " << std::put_time(ptm,"%X") << '\n';
 std::cout << "Waiting for the next minute to begin...\n";
 ++ptm->tm_min; ptm->tm_sec=0;
 std::this_thread::sleep_until (system_clock::from_time_t (mktime(ptm)));
 std::cout << std::put_time(ptm,"%X") << " reached!\n";
 return 0;
}

Output (after an avg. of 30 seconds):
Current time: 11:52:36
Waiting for the next minute to begin...
11:53:00 reached!


Exception safety

If the type of abs_time never throws exceptions (like if it only uses values from the standard clocks provided in header <chrono> ), this function never throws exceptions (no-throw guarantee).

See also

yield
Yield to other threads (function)
sleep_for
Sleep for time span (function)

AltStyle によって変換されたページ (->オリジナル) /