Namespaces
Variants
Actions

std::this_thread::sleep_for

From cppreference.com
< cpp‎ | thread
 
 
Concurrency support library
Threads
(C++11)
(C++20)
this_thread namespace
(C++11)
(C++11)
sleep_for
(C++11)
Cooperative cancellation
Mutual exclusion
Generic lock management
(C++11)
(C++11)
(C++11)
(C++11)
Condition variables
(C++11)
Semaphores
Latches and Barriers
(C++20)
(C++20)
Futures
(C++11)
(C++11)
(C++11)
Safe reclamation
Hazard pointers
Atomic types
(C++11)
(C++20)
Initialization of atomic types
(C++11)(deprecated in C++20)
(C++11)(deprecated in C++20)
Memory ordering
(C++11)(deprecated in C++26)
Free functions for atomic operations
Free functions for atomic flags
 
Defined in header <thread>
template<class Rep, class Period >
void sleep_for(conststd::chrono::duration<Rep, Period>& sleep_duration );
(since C++11)

Blocks the execution of the current thread for at least the specified sleep_duration.

This function may block for longer than sleep_duration due to scheduling or resource contention delays.

The standard recommends that a steady clock is used to measure the duration. If an implementation uses a system clock instead, the wait time may also be sensitive to clock adjustments.

Contents

[edit]Parameters

sleep_duration - time duration to sleep

[edit]Return value

(none)

[edit]Exceptions

Any exception thrown by clock, time_point, or duration during the execution (clocks, time points, and durations provided by the standard library never throw).

[edit]Example

#include <chrono>#include <iostream>#include <thread>   int main(){usingnamespace std::chrono_literals;   std::cout<<"Hello waiter\n"<<std::flush;   constauto start =std::chrono::high_resolution_clock::now(); std::this_thread::sleep_for(2000ms);constauto end =std::chrono::high_resolution_clock::now();conststd::chrono::duration<double, std::milli> elapsed = end - start;   std::cout<<"Waited "<< elapsed <<'\n';}

Possible output:

Hello waiter Waited 2000.13 ms

[edit]See also

stops the execution of the current thread until a specified time point
(function)[edit]
close