std::thread::thread
Материал из cppreference.com
|
|
Эта страница была переведена автоматически с английской версии вики используя Переводчик Google. Перевод может содержать ошибки и странные формулировки. Наведите курсор на текст, чтобы увидеть оригинал. Щёлкните здесь, чтобы увидеть английскую версию этой страницы. (Вы можете помочь в исправлении ошибок и улучшении перевода. Для инструкций перейдите по ссылке.) |
thread(); |
(1) | (начиная с C++11) |
thread( thread&& other ); |
(2) | (начиная с C++11) |
template< class Function, class... Args > explicit thread( Function&& f, Args&&... args ); |
(3) | (начиная с C++11) |
thread(const thread&) = delete; |
(4) | (начиная с C++11) |
Создает новый объект потока.
Оригинал:
Constructs new thread object.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
1)
Создает новый объект потока, который не представляет собой поток.
Оригинал:
Creates new thread object which does not represent a thread.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
2)
Конструктор перемещения. Создает объект потока, из потока
other. После этого вызова other больше не представляет поток выполнения.Оригинал:
Move constructor. Constructs the thread object to represent the thread of execution that was represented by
other. After this call other no longer represents a thread of execution.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
3)
Создает новый объект
std::thread и связывает его с потоком выполнения. Первый конструктор копирует все аргументы args... в локальную память потока, как функция:Оригинал:
Creates new
std::thread object and associates it with a thread of execution. First the constructor copies all arguments args... to thread-local storage as if by the function:Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
template <class T>
typename decay<T>::type decay_copy(T&& v) {
return std::forward<T>(v);
}
Любые исключения, создаются в текущем потоке, а не в новом.
Код, который будет выполняться в новом потоке определяется следующим образом. Обратимся к None
copied_args, как t1, t2,..., tN, где N является sizeof...(copied_args)and copied_args is the result of calling decay_copy as defined above. The following code will be run in the new thread: - Если
fявляется указателем на функцию-член классаT, то она называется. Возвращаемое значение игнорируется. По сути, выполняется следующий код:Оригинал:Iffis pointer to a member function of classT, then it is called. The return value is ignored. Effectively, the following code is executed:Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
(t1.*f)(t2, ..., tN), если типt1либоT, ссылка наTили ссылка на тип, производный отT.Оригинал:(t1.*f)(t2, ..., tN)if the type oft1is eitherT, reference toTor reference to type derived fromT.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.((*t1).*f)(t2, ..., tN)иначе.Оригинал:((*t1).*f)(t2, ..., tN)otherwise.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
- Если
N == 1иfявляется указателем на объект элемента данных класса, то при обращении к нему. Стоимость объекта игнорируются. По сути, выполняется следующий код:Оригинал:IfN == 1andfis pointer to a member data object of a class, then it is accessed. The value of the object is ignored. Effectively, the following code is executed:Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
t1.*fесли и типt1либоT, ссылка наTили ссылка на тип, производный отT.Оригинал:t1.*fif and the type oft1is eitherT, reference toTor reference to type derived fromT.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.(*t1).*fиначе.Оригинал:(*t1).*fotherwise.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
fназывается указателем на не являющихся членами функции во всех остальных случаях. Возвращаемое значение игнорируется. По сути,f(t1, t2, ..., tN)выполняется.Оригинал:fis called as a pointer to a non-member function in all other cases. The return value is ignored. Effectively,f(t1, t2, ..., tN)is executed.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Оригинал:
The code that will be run in the new thread is defined as follows. Обратимся к None
copied_args, как t1, t2,..., tN, где N является sizeof...(copied_args)and copied_args is the result of calling decay_copy as defined above. The following code will be run in the new thread: - Если
fявляется указателем на функцию-член классаT, то она называется. Возвращаемое значение игнорируется. По сути, выполняется следующий код:Оригинал:Iffis pointer to a member function of classT, then it is called. The return value is ignored. Effectively, the following code is executed:Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
(t1.*f)(t2, ..., tN), если типt1либоT, ссылка наTили ссылка на тип, производный отT.Оригинал:(t1.*f)(t2, ..., tN)if the type oft1is eitherT, reference toTor reference to type derived fromT.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.((*t1).*f)(t2, ..., tN)иначе.Оригинал:((*t1).*f)(t2, ..., tN)otherwise.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
- Если
N == 1иfявляется указателем на объект элемента данных класса, то при обращении к нему. Стоимость объекта игнорируются. По сути, выполняется следующий код:Оригинал:IfN == 1andfis pointer to a member data object of a class, then it is accessed. The value of the object is ignored. Effectively, the following code is executed:Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
t1.*fесли и типt1либоT, ссылка наTили ссылка на тип, производный отT.Оригинал:t1.*fif and the type oft1is eitherT, reference toTor reference to type derived fromT.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.(*t1).*fиначе.Оригинал:(*t1).*fotherwise.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
fназывается указателем на не являющихся членами функции во всех остальных случаях. Возвращаемое значение игнорируется. По сути,f(t1, t2, ..., tN)выполняется.Оригинал:fis called as a pointer to a non-member function in all other cases. The return value is ignored. Effectively,f(t1, t2, ..., tN)is executed.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
4)
Конструктор копирования удалён; объекты не копируемые.
Оригинал:
The copy constructor is deleted; threads are not copyable. No two
std::thread objects may represent the same thread of execution.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Параметры
| other | — | другой объект потока
Оригинал: another thread object to construct this thread object with Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
| f | — | Функция для выполнения в новом потоке
Оригинал: function to execute in the new thread Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
| args... | — | Аргументы функции выполнения
Оригинал: arguments to pass to the new function Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
Исключения
1-2)
спецификация noexcept:
noexcept3) std::system_error, если поток не может быть запущен. Исключение может представлять
std::errc::resource_unavailable_try_again или другую ошибку, зависящую от конкретной реализации.Заметки
Аргументы функции потока копируются по значению. Если ссылочный аргумент должен быть передан функции потока, он должен быть обернут (например, с std::ref или std::cref).
Оригинал:
The arguments to the thread function are copied by value. If a reference argument needs to be passed to the thread function, it has to be wrapped (e.g. with std::ref or std::cref).
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Любое возвращаемое значение функции игнорируется. Если функция генерирует исключение, вызывается std::terminate. Используйте std::promise или std::async для проброса возвращаемых значений и исключений в вызывающий поток.
Оригинал:
Any return value from the function is ignored. If the function throws an exception, std::terminate is called. In order to pass return values or exceptions back to the calling thread, std::promise or std::async may be used.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Пример
Запустить этот код
#include <iostream>
#include <utility>
#include <thread>
#include <chrono>
#include <functional>
#include <atomic>
void f1(int n)
{
for(int i=0; i<5; ++i) {
std::cout << "Thread " << n << " executing\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));
}
}
int main()
{
int n = 0;
std::thread t1; // t1 is not a thread
std::thread t2(f1, n+1); // pass by value
std::thread t3(f2, std::ref(n)); // pass by reference
std::thread t4(std::move(t3)); // t4 is now running f2(). t3 is no longer a thread
t2.join();
t4.join();
std::cout << "Final value of n is " << n << '\n';
}
Возможный вывод:
Thread 1 executing
Thread 2 executing
Thread 1 executing
Thread 2 executing
Thread 1 executing
Thread 2 executing
Thread 1 executing
Thread 2 executing
Thread 1 executing
Thread 2 executing
Final value of n is 5