命名空间
变体
操作

std::jthread::joinable

来自 cppreference.cn
< cpp‎ | thread‎ | jthread
 
 
并发支持库
线程
(C++11)
(C++20)
this_thread 命名空间
(C++11)
(C++11)
(C++11)
协作取消
互斥
(C++11)
通用锁管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
条件变量
(C++11)
信号量
闩锁和栅栏
(C++20)
(C++20)
期物
(C++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
危害指针
原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中已弃用)
(C++11)(C++20 中已弃用)
内存顺序
(C++11)(C++26 中已弃用)
原子操作的自由函数
原子标志的自由函数
 
 
bool joinable() const noexcept;
(自 C++20 起)

检查 std::jthread 对象是否标识一个活动的执行线程。具体来说,如果 get_id() != std::jthread::id(),则返回 true。因此,默认构造的 jthread 是不可连接的。

一个已经完成代码执行但尚未被连接的线程仍被视为活动的执行线程,因此是可连接的。

目录

[edit] 参数

(无)

[edit] 返回值

如果 std::jthread 对象标识一个活动的执行线程,则为 true,否则为 false。

[edit] 示例

#include <chrono>
#include <iostream>
#include <thread>
using namespace std::chrono_literals;
 
void foo()
{
    std::this_thread::sleep_for(500ms);
}
 
int main()
{
    std::cout << std::boolalpha;
 
    std::jthread t;
    std::cout << "before starting, joinable: " << t.joinable() << '\n';
 
    t = std::jthread{foo};
    std::cout << "after starting, joinable: " << t.joinable() << '\n';
 
    t.join();
    std::cout << "after joining, joinable: " << t.joinable() << '\n';
 
    t = std::jthread{foo};
    t.detach();
    std::cout << "after detaching, joinable: " << t.joinable() << '\n';
 
}

输出

before starting, joinable: false
after starting, joinable: true
after joining, joinable: false
after detaching, joinable: false

[edit] 参考文献

  • C++23 标准 (ISO/IEC 14882:2024)
  • 33.4.4.3 成员 [thread.jthread.mem]
  • C++20 标准 (ISO/IEC 14882:2020)
  • 32.4.3.2 成员 [thread.jthread.mem]

[edit] 参见

返回线程的 id
(公共成员函数) [edit]
等待线程完成其执行
(公共成员函数) [edit]
允许线程独立于线程句柄执行
(公共成员函数) [edit]