std::packaged_task::reset - cppreference.com
De cppreference.com
|
|
(desde C++11) | |
Restablece el estado abandonando los resultados de ejecuciones anteriores. Se construye un nuevo estado compartido.
Equivalente a *this = packaged_task(std::move(f)), donde f es la tarea almacenada.
Parámetros
(Ninguno)
Valor de retorno
(Ninguno)
Excepciones
- std::future_error si
*thisno tiene un estado compartido. La condición de error se establece a no_state. - std::bad_alloc si no hubo suficiente memoria para el nuevo estado compartido.
- Cualquier excepción lanzada por el constructor de movimiento del nuevo objeto
packaged_task.
Ejemplo
#include <iostream> #include <cmath> #include <thread> #include <future> int main() { std::packaged_task<int(int,int)> task([](int a, int b) { return std::pow(a, b); }); std::future<int> result = task.get_future(); task(2, 9); std::cout << "2^9 = " << result.get() << '\n'; task.reset(); result = task.get_future(); std::thread task_td(std::move(task), 2, 10); task_td.join(); std::cout << "2^10 = " << result.get() << '\n'; }
Salida: