std::jthread::joinable
From cppreference.com
                    
                                        
                    
                    
                                                            
                    
| [[nodiscard]] bool joinable() const noexcept; | (since C++20) | |
Checks if the std::jthread object identifies an active thread of execution. Specifically, returns true if get_id() != std::jthread::id(). So a default constructed jthread is not joinable. 
A thread that has finished executing code, but has not yet been joined is still considered an active thread of execution and is therefore joinable.
Parameters
(none)
Return value
true if the jthread object identifies an active thread of execution, false otherwise
Example
Run this code
#include <iostream> #include <thread> #include <chrono> void foo() { std::this_thread::sleep_for(std::chrono::seconds(1)); } int main() { std::jthread t; std::cout << "before starting, joinable: " << std::boolalpha << t.joinable() << '\n'; t = std::thread(foo); std::cout << "after starting, joinable: " << t.joinable() << '\n'; t.join(); std::cout << "after joining, joinable: " << t.joinable() << '\n'; }
Output:
before starting, joinable: false after starting, joinable: true after joining, joinable: false
See also
| returns the id of the thread (public member function) | |
| waits for a thread to finish its execution (public member function) | |
| permits the thread to execute independently from the thread handle (public member function) | 
References
| This section is incomplete Reason: will be completed by C++20 FDIS |