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

C++怎么使用C++20的std::jthread_C++并发编程与可中断线程

尼克
发布: 2025-11-26 15:16:49
原创
320人浏览过
std::jthread是C++20引入的现代化线程类,位于<thread>头文件中,其“j”代表joining,意味着在线程对象析构时会自动调用join(),避免资源泄漏。相比std::thread,std::jthread不仅提供自动合流能力,还内置了协作式中断机制,通过std::stop_token、std::stop_source和std::stop_callback支持安全的线程取消。使用时只需将可调用对象传入jthread构造函数,若需中断支持,则函数或lambda需接收std::stop_token作为第一参数,并在执行中定期检查stop_requested()状态。调用request_stop()后,关联的stop_token会通知任务退出,同时可注册stop_callback进行资源清理。因此,在C++20及以上版本中应优先使用std::jthread以提升并发编程的安全性与简洁性。

c++怎么使用c++20的std::jthread_c++并发编程与可中断线程

在C++20中,std::jthread 是对 std::thread 的现代化改进,它不仅具备自动合流(join)的能力,还内置了线程中断机制,使得并发编程更安全、更简洁。相比传统线程管理方式,jthread 能有效避免资源泄漏和死锁问题。

什么是 std::jthread?

std::jthread(joining thread)是 C++20 引入的新类型,位于 <thread> 头文件中。它的“j”代表“joining”,意味着在线程对象析构时会自动调用 join(),无需手动管理生命周期。

jthread 还整合了 std::stop_tokenstd::stop_sourcestd::stop_callback,支持安全的协作式中断机制——这是传统 std::thread 所不具备的关键能力。

基本用法:替代 std::thread

使用 jthread 和使用 thread 非常相似,但更安全:

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

#include <iostream>
#include <thread>
#include <chrono>

void task() {
    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(task); // 自动 join,无需 t.join()
    t.join(); // 可显式调用,也可省略
    return 0;
}
登录后复制

即使你忘记调用 join(),jthread 析构时也会自动完成,防止程序终止时报错。

线程中断:协作式取消

jthread 最大的优势是支持中断。通过 stop_token 检查是否收到停止请求,实现安全退出。

新CG儿
新CG儿

数字视觉分享平台 | AE模板_视频素材

新CG儿 412
查看详情 新CG儿
#include <iostream>
#include <thread>
#include <chrono>

void cancellable_task(std::stop_token stoken) {
    for (int i = 0; i < 100; ++i) {
        if (stoken.stop_requested()) {
            std::cout << "Task cancelled.\n";
            return;
        }
        std::this_thread::sleep_for(std::chrono::milliseconds(50));
        std::cout << "Step " << i << "\n";
    }
    std::cout << "Task completed.\n";
}

int main() {
    std::jthread t(cancellable_task);
    
    std::this_thread::sleep_for(std::chrono::milliseconds(300));
    t.request_stop(); // 请求中断

    return 0;
}
登录后复制

在这个例子中,cancellable_task 接收一个 std::stop_token 参数。调用 t.request_stop() 后,stop_token 会感知到请求,任务可据此退出循环。

使用 lambda 支持中断

你也可以在 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 task stopped.\n";
});

std::this_thread::sleep_for(std::chrono::seconds(3));
t.request_stop();
登录后复制

注意:lambda 必须接受 std::stop_token 作为第一个参数,运行时系统会自动传入。

stop_callback:清理资源

你可以注册回调函数,在中断请求发出时执行清理操作:

std::jthread t([](std::stop_token stoken) {
    std::stop_callback guard(stoken, []{
        std::cout << "Cleaning up resources...\n";
    });

    while (!stoken.stop_requested()) {
        std::cout << "Processing...\n";
        std::this_thread::sleep_for(std::chrono::milliseconds(200));
    }
});
std::this_thread::sleep_for(std::chrono::milliseconds(600));
t.request_stop();
登录后复制

当 request_stop() 被调用时,guard 的回调会触发,适合关闭文件、释放内存等操作。

基本上就这些。std::jthread 让 C++ 并发更现代、更安全。它把自动合流和中断机制集成在一起,显著减少了出错可能。如果你用的是 C++20 或更高版本,优先选择 jthread 而不是 thread。不复杂但容易忽略的是:确保可中断函数正确接收 stop_token 并定期检查状态。这样你的多线程代码才能真正响应外部控制。

以上就是C++怎么使用C++20的std::jthread_C++并发编程与可中断线程的详细内容,更多请关注php中文网其它相关文章!

编程速学教程(入门课程)
编程速学教程(入门课程)

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

下载
来源: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号