您的位置:首页 >C++ std::jthread使用详解
发布于2025-12-26 阅读(0)
扫一扫,手机访问
std::jthread在C++20中引入,析构时自动join,支持stop_token协作式停止,简化线程管理并避免资源泄漏。

从 C++20 开始,std::jthread 被引入作为对 std::thread 的改进版本,它最大的优势是自动管理线程生命周期,无需手动调用 join() 或 detach(),并且支持外部请求停止(cooperative interruption)。
std::jthread 具备以下关键特性:
下面是一个简单的例子,展示如何使用 std::jthread 启动一个线程并让它自动回收:
#include <thread>
#include <iostream>
#include <chrono>
void worker() {
for (int i = 0; i < 5; ++i) {
std::this_thread::sleep_for(std::chrono::milliseconds(100));
std::cout << "Working... " << i << "\n";
}
}
int main() {
std::jthread t(worker); // 自动启动线程
// 不需要 t.join(),析构时会自动 join
return 0;
}
在这个例子中,main 函数结束时,t 被销毁,jthread 内部自动调用 join() 等待线程完成。
std::jthread 支持通过 std::stop_token 检测是否收到停止请求,实现安全退出。这是它比 std::thread 更强大的地方。
#include <thread>
#include <iostream>
#include <chrono>
void cancellable_worker(std::stop_token stoken) {
for (int i = 0; i < 100; ++i) {
if (stoken.stop_requested()) {
std::cout << "Stop requested! Exiting gracefully.\n";
return;
}
std::this_thread::sleep_for(std::chrono::milliseconds(50));
std::cout << "Loop " << i << "\n";
}
}
int main() {
std::jthread t(cancellable_worker);
std::this_thread::sleep_for(std::chrono::milliseconds(200));
t.request_stop(); // 请求线程停止
// 析构时自动 join
return 0;
}
注意函数参数中的 std::stop_token,jthread 会自动将自身的停止机制传入该函数。调用 t.request_stop() 后,线程会在下一次检查 stop_token 时退出。
你也可以在 lambda 表达式中使用 stop_token:
std::jthread t([](std::stop_token stoken) {
while (!stoken.stop_requested()) {
std::cout << "Running...\n";
std::this_thread::sleep_for(std::chrono::seconds(1));
}
std::cout << "Lambda thread stopped.\n";
});
std::this_thread::sleep_for(std::chrono::seconds(3));
t.request_stop();
如果需要访问底层的 std::thread,可以使用 get_id() 或通过 native_handle() 获取原生句柄(视平台而定):
std::cout << "Thread ID: " << t.get_id() << "\n";
基本上就这些。std::jthread 让多线程编程更安全、更简洁,尤其适合需要自动清理和可取消操作的场景。只要你的编译器支持 C++20(如 GCC 11+、Clang 14+、MSVC 19.29+),就可以放心使用。
上一篇:租号玩怎么租号-租用账号方法教程
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9