Standard library header <thread> (C++11)
From cppreference.com
This header is part of the thread support library.
Includes | |
(C++20) |
Three-way comparison operator support |
Namespaces | |
this_thread
|
provide functions that access the current thread of execution |
Classes | |
(C++11) |
manages a separate thread (class) |
(C++20) |
std::thread with support for auto-joining and cancellation (class) |
| specializes std::hash (class template specialization) | |
Functions | |
(C++11) |
specializes the std::swap algorithm (function) |
(removed in C++20)(removed in C++20)(removed in C++20)(removed in C++20)(removed in C++20)(C++20) |
compares two thread::id objects (function) |
serializes a thread::id object (function template) | |
Defined in namespace
std::this_thread | |
(C++11) |
suggests that the implementation reschedule execution of threads (function) |
(C++11) |
returns the thread id of the current thread (function) |
(C++11) |
stops the execution of the current thread for a specified time duration (function) |
(C++11) |
stops the execution of the current thread until a specified time point (function) |
Synopsis
#include <compare>
namespace std {
// class thread
class thread;
void swap(thread& x, thread& y) noexcept;
// class jthread
class jthread;
// namespace this_thread
namespace this_thread {
thread::id get_id() noexcept;
void yield() noexcept;
template<class Clock, class Duration>
void sleep_until(const chrono::time_point<Clock, Duration>& abs_time);
template<class Rep, class Period>
void sleep_for(const chrono::duration<Rep, Period>& rel_time);
}
}
Class std::thread
namespace std {
class thread
{
public:
// class thread::id
class id;
using native_handle_type = /* implementation-defined */;
// construct/copy/destroy
thread() noexcept;
template<class F, class... Args>
explicit thread(F&& f, Args&&... args);
~thread();
thread(const thread&) = delete;
thread(thread&&) noexcept;
thread& operator=(const thread&) = delete;
thread& operator=(thread&&) noexcept;
// members
void swap(thread&) noexcept;
bool joinable() const noexcept;
void join();
void detach();
id get_id() const noexcept;
native_handle_type native_handle();
// static members
static unsigned int hardware_concurrency() noexcept;
};
}
Class std::jthread
namespace std {
class jthread
{
public:
// types
using id = thread::id;
using native_handle_type = thread::native_handle_type;
// constructors, move, and assignment
jthread() noexcept;
template<class F, class... Args>
explicit jthread(F&& f, Args&&... args);
~jthread();
jthread(const jthread&) = delete;
jthread(jthread&&) noexcept;
jthread& operator=(const jthread&) = delete;
jthread& operator=(jthread&&) noexcept;
// members
void swap(jthread&) noexcept;
bool joinable() const noexcept;
void join();
void detach();
id get_id() const noexcept;
native_handle_type native_handle();
// stop token handling
stop_source get_stop_source() noexcept;
stop_token get_stop_token() const noexcept;
bool request_stop() noexcept;
// specialized algorithms
friend void swap(jthread& lhs, jthread& rhs) noexcept;
// static members
static unsigned int hardware_concurrency() noexcept;
private:
stop_source ssource; // exposition only
};
}
Class std::thread::id
namespace std {
class thread::id
{
public:
id() noexcept;
};
bool operator==(thread::id x, thread::id y) noexcept;
strong_ordering operator<=>(thread::id x, thread::id y) noexcept;
template<class CharT, class Traits>
basic_ostream<CharT, Traits>& operator<<(basic_ostream<CharT, Traits>& out,
thread::id id);
template<class CharT>
struct formatter<thread::id, CharT>;
// hash support
template<class T>
struct hash;
template<>
struct hash<thread::id>;
}