std::stop_token:: stop_possible
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||
| Modifiers | ||||
| Observers | ||||
|
stop_token::stop_possible
|
||||
| Non-member functions | ||||
|
bool
stop_possible
(
)
const
noexcept
;
|
(desde C++20) | |
Comprueba si el objeto
stop_token
tiene un estado de parada asociado, y que dicho estado ya ha recibido una solicitud de parada o tiene objetos
std::stop_source
asociados.
Un stop_token construido por defecto no tiene estado de parada asociado, y por lo tanto no puede ser detenido; el estado de parada asociado para el cual no existen objetos std::stop_source tampoco puede ser detenido si dicha solicitud no se ha realizado previamente.
Contenidos |
Parámetros
(ninguno)
Valor de retorno
false
si el objeto
stop_token
no tiene un estado de parada asociado, o si aún no ha recibido una solicitud de parada y no hay objetos
std::stop_source
asociados;
true
en caso contrario.
Notas
Si el
stop_token
tiene un estado de parada asociado y ya se ha realizado una solicitud de parada, esta función aún devuelve
true
.
Si el objeto
stop_token
tiene un estado de parada asociado de un
std::jthread
—por ejemplo, el
stop_token
se obtuvo invocando
get_stop_token
(
)
en un objeto
std::jthread
—entonces esta función siempre devuelve
true
. Un
std::jthread
siempre tiene un objeto interno
std::stop_source
, incluso si la función invocada del hilo no lo verifica.
Ejemplo
#include <chrono> #include <condition_variable> #include <format> #include <iostream> #include <mutex> #include <string_view> #include <thread> using namespace std::chrono_literals; int main() { std::cout << std::boolalpha; auto print = [](std::string_view name, const std::stop_token& token) { std::cout << std::format("{}: stop_possible = {:s}, stop_requested = {:s}\n", name, token.stop_possible(), token.stop_requested() ); }; // Un hilo trabajador que escuchará solicitudes de parada auto stop_worker = std::jthread([](std::stop_token stoken) { for (int i = 10; i; --i) { std::this_thread::sleep_for(300ms); if (stoken.stop_requested()) { std::cout << " Al trabajador somnoliento se le solicita parar\n"; return; } std::cout << " El trabajador somnoliento vuelve a dormir\n"; } }); // Un hilo trabajador que solo se detendrá cuando finalice auto inf_worker = std::jthread([]() { for (int i = 5; i; --i) { std::this_thread::sleep_for(300ms); std::cout << " Ejecutar tanto como queramos\n"; } }); std::stop_token def_token; std::stop_token stop_token = stop_worker.get_stop_token(); std::stop_token inf_token = inf_worker.get_stop_token(); print("def_token ", def_token); print("stop_token", stop_token); print("inf_token ", inf_token); std::cout << "\nSolicitar y unir stop_worker:\n"; stop_worker.request_stop(); stop_worker.join(); std::cout << "\nSolicitar y unir inf_worker:\n"; inf_worker.request_stop(); inf_worker.join(); std::cout << '\n'; print("def_token ", def_token); print("stop_token", stop_token); print("inf_token ", inf_token); }
Salida posible:
def_token : stop_possible = false, stop_requested = false stop_token: stop_possible = true, stop_requested = false inf_token : stop_possible = true, stop_requested = false Request and join stop_worker: Run as long as we want Sleepy worker is requested to stop Request and join inf_worker: Run as long as we want Run as long as we want Run as long as we want Run as long as we want def_token : stop_possible = false, stop_requested = false stop_token: stop_possible = true, stop_requested = true inf_token : stop_possible = true, stop_requested = true