std::thread:: thread
|
thread
(
)
noexcept
;
|
(1) | (начиная с C++11) |
|
thread
(
thread
&&
other
)
noexcept
;
|
(2) | (начиная с C++11) |
|
template
<
class
F,
class
...
Args
>
explicit thread ( F && f, Args && ... args ) ; |
(3) | (начиная с C++11) |
|
thread
(
const
thread
&
)
=
delete
;
|
(4) | (начиная с C++11) |
Создает новый объект
std::thread
.
std::thread
, который не представляет поток выполнения.
std::thread
для представления потока выполнения, который был представлен объектом
other
. После этого вызова
other
больше не представляет поток выполнения.
std::thread
и связывает его с потоком выполнения. Новый поток выполнения начинает выполнение:
|
INVOKE
(
decay-copy
(
std::
forward
<
F
>
(
f
)
)
,
|
(до C++23) |
|
std::
invoke
(
auto
(
std::
forward
<
F
>
(
f
)
)
,
|
(начиная с C++23) |
std::thread
.
|
Если выполняется любое из следующих условий, программа является некорректной:
|
(до C++20) |
|
Если любое из следующего является false , программа является некорректной:
|
(начиная с C++20) |
std::thread
объекта не могут представлять один и тот же поток выполнения.
Содержание |
Параметры
| other | - | другой объект потока для конструирования данного объекта потока |
| f | - | Callable объект для выполнения в новом потоке |
| args | - | аргументы для передачи новой функции |
Постусловия
Исключения
std::errc::resource_unavailable_try_again
или другую реализационно-зависимую ошибку.
Примечания
Аргументы функции потока перемещаются или копируются по значению. Если необходимо передать ссылочный аргумент в функцию потока, его следует обернуть (например, с помощью std::ref или std::cref ).
Любое возвращаемое значение функции игнорируется. Если функция выбрасывает исключение, std::terminate вызывается. Для передачи возвращаемых значений или исключений обратно в вызывающий поток, std::promise или std::async могут быть использованы.
Пример
#include <chrono> #include <iostream> #include <thread> #include <utility> void f1(int n) { for (int i = 0; i < 5; ++i) { std::cout << "Thread 1 executing\n"; ++n; std::this_thread::sleep_for(std::chrono::milliseconds(10)); } } void f2(int& n) { for (int i = 0; i < 5; ++i) { std::cout << "Thread 2 executing\n"; ++n; std::this_thread::sleep_for(std::chrono::milliseconds(10)); } } class foo { public: void bar() { for (int i = 0; i < 5; ++i) { std::cout << "Thread 3 executing\n"; ++n; std::this_thread::sleep_for(std::chrono::milliseconds(10)); } } int n = 0; }; class baz { public: void operator()() { for (int i = 0; i < 5; ++i) { std::cout << "Thread 4 executing\n"; ++n; std::this_thread::sleep_for(std::chrono::milliseconds(10)); } } int n = 0; }; int main() { int n = 0; foo f; baz b; std::thread t1; // t1 не является потоком std::thread t2(f1, n + 1); // передача по значению std::thread t3(f2, std::ref(n)); // передача по ссылке std::thread t4(std::move(t3)); // t4 теперь выполняет f2(). t3 больше не является потоком std::thread t5(&foo::bar, &f); // t5 выполняет foo::bar() на объекте f std::thread t6(b); // t6 выполняет baz::operator() на копии объекта b t2.join(); t4.join(); t5.join(); t6.join(); std::cout << "Final value of n is " << n << '\n'; std::cout << "Final value of f.n (foo::n) is " << f.n << '\n'; std::cout << "Final value of b.n (baz::n) is " << b.n << '\n'; }
Возможный вывод:
Thread 1 executing Thread 2 executing Thread 3 executing Thread 4 executing Thread 3 executing Thread 1 executing Thread 2 executing Thread 4 executing Thread 2 executing Thread 3 executing Thread 1 executing Thread 4 executing Thread 3 executing Thread 2 executing Thread 1 executing Thread 4 executing Thread 3 executing Thread 1 executing Thread 2 executing Thread 4 executing Final value of n is 5 Final value of f.n (foo::n) is 5 Final value of b.n (baz::n) is 0
Отчеты о дефектах
Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Применяется к | Поведение в опубликованной версии | Корректное поведение |
|---|---|---|---|
| LWG 2097 | C++11 |
для перегрузки
(3)
,
F
мог быть
std::thread
|
F
ограничен
|
| LWG 3476 | C++20 |
перегрузка
(3)
напрямую требовала (деградированные типы)
F
и типы аргументов должны были быть перемещаемыми
|
удалены эти
требования [1] |
- ↑ Конструируемость перемещением уже косвенно требуется std::is_constructible_v .
Ссылки
- Стандарт C++23 (ISO/IEC 14882:2024):
-
- 33.4.3.3 конструкторы thread [thread.thread.constr]
- Стандарт C++20 (ISO/IEC 14882:2020):
-
- 32.4.2.2 Конструкторы thread [thread.thread.constr]
- Стандарт C++17 (ISO/IEC 14882:2017):
-
- 33.3.2.2 Конструкторы thread [thread.thread.constr]
- Стандарт C++14 (ISO/IEC 14882:2014):
-
- 30.3.1.2 Конструкторы thread [thread.thread.constr]
- Стандарт C++11 (ISO/IEC 14882:2011):
-
- 30.3.1.2 Конструкторы потоков [thread.thread.constr]
Смотрите также
создает новый объект
jthread
(публичная функция-член
std::jthread
)
|
|
|
Документация C
для
thrd_create
|
|