Namespaces
Variants

std::thread:: ~thread

From cppreference.net
Concurrency support library
Threads
(C++11)
(C++20)
this_thread namespace
(C++11)
(C++11)
Cooperative cancellation
Mutual exclusion
Generic lock management
Condition variables
(C++11)
Semaphores
Latches and Barriers
(C++20)
(C++20)
Futures
(C++11)
(C++11)
(C++11)
Safe reclamation
Hazard pointers
Atomic types
(C++11)
(C++20)
Initialization of atomic types
(C++11) (deprecated in C++20)
(C++11) (deprecated in C++20)
Memory ordering
(C++11) (deprecated in C++26)
Free functions for atomic operations
Free functions for atomic flags
~thread ( ) ;
(depuis C++11)

Détruit l'objet thread.

Si * this a un thread associé ( joinable ( ) == true ), std:: terminate ( ) est appelée.

Notes

Un objet thread n'a pas de thread associé (et peut être détruit sans risque) après

  • il a été construit par défaut.
  • il a été déplacé.
  • join() a été appelé.
  • detach() a été appelé.

Exemple

#include <thread>
using namespace std::chrono_literals;
int main()
{
    auto bleah = std::thread{[]{ std::this_thread::sleep_for(13ms); }};
}   // ~thread appelle std::terminate()

Sortie possible :

terminate called without an active exception

Voir aussi

si le thread est joignable, alors un arrêt est demandé et le thread se joint
(fonction membre publique de std::jthread )