首页 > 后端开发 > C++ > 正文

c++20的std::jthread是什么_c++可中断线程与RAII式管理

裘德小鎮的故事
发布: 2025-12-01 14:47:02
原创
788人浏览过
std::jthread是C++20引入的自动管理线程生命周期并支持协作式中断的线程类,析构时自动调用join()避免资源泄漏,并通过stop_token等机制实现安全停止。

c++20的std::jthread是什么_c++可中断线程与raii式管理

在 C++20 中,std::jthread 是对传统 std::thread 的改进版本,它引入了两个关键特性:自动资源管理(RAII)和线程中断支持。这使得多线程编程更安全、更简洁,尤其适合需要可靠生命周期管理和协作式中断的场景。

什么是 std::jthread?

std::jthread 全称是 "joining thread",它本质上是一个可自动调用 join() 的线程对象。与 std::thread 不同,即使你忘记显式调用 join() 或 detach(),jthread 在析构时会自动等待线程结束,避免程序因未回收线程而崩溃。

此外,std::jthread 内建了协作式中断机制,通过 std::stop_tokenstd::stop_sourcestd::stop_callback 实现线程的优雅终止。

RAII 式线程管理:告别资源泄漏

使用 std::thread 时,如果线程对象超出作用域前没有调用 join() 或 detach(),程序会调用 std::terminate() 终止。这种设计容易导致资源泄漏或崩溃。

立即学习C++免费学习笔记(深入)”;

std::jthread 解决了这个问题:

瞬映
瞬映

AI 快速创作数字人视频,一站式视频创作平台,让视频创作更简单。

瞬映 57
查看详情 瞬映
  • 构造时启动线程任务
  • 析构时自动调用 join(),确保线程完成
  • 无需手动管理线程生命周期,符合 RAII 原则
示例代码:
void worker() {
    for (int i = 0; i < 10; ++i) {
        std::this_thread::sleep_for(std::chrono::milliseconds(100));
        std::cout << "Working... " << i << "\n";
    }
}

int main() {
    std::jthread t(worker); // 启动线程
    std::this_thread::sleep_for(std::chrono::milliseconds(500));
    // 析构时自动 join,无需手动操作
    return 0;
} // t 离开作用域,自动等待 worker 结束
登录后复制

协作式中断:安全停止线程

C++20 提供了一套标准的中断机制,让线程可以被外部请求停止,并在线程内部安全响应。

核心组件:

  • std::stop_token:线程用来查询是否收到停止请求
  • std::stop_source:用于发出停止信号
  • std::stop_callback:注册回调函数,在收到停止请求时执行清理工作

std::jthread 构造时会自带一个 std::stop_source,你可以通过 get_stop_token() 获取 token 来监听中断。

带中断处理的示例:
void interruptible_worker(std::stop_token stoken) {
    while (!stoken.stop_requested()) {
        std::cout << "Doing work...\n";
        for (int i = 0; i < 10; ++i) {
            if (stoken.stop_requested()) break;
            std::this_thread::sleep_for(std::chrono::milliseconds(100));
        }
    }
    std::cout << "Worker stopped.\n";
}

int main() {
    std::jthread t(interruptible_worker);
    std::this_thread::sleep_for(std::chrono::milliseconds(500));
    t.request_stop(); // 请求线程停止
    // 析构时自动 join
    return 0;
}
登录后复制

对比 std::thread:优势在哪?

  • 自动 join():消除因忘记 join 导致的运行时错误
  • 内置中断支持:无需依赖全局变量或标志位实现线程取消
  • 类型安全:中断机制是标准库的一部分,避免平台相关实现
  • 可组合性好:配合 stop_callback 可做资源清理、取消异步操作等

对于长期运行或可能提前终止的任务,std::jthread 明显优于原始 std::thread

基本上就这些。std::jthread 让 C++ 多线程更现代、更安全,把 RAII 和协作中断结合得很好,写起来也更省心。

以上就是c++++20的std::jthread是什么_c++可中断线程与RAII式管理的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号