std::thread 提供类型安全的线程管理,支持函数、lambda 创建线程,需用 join 或 detach 避免终止,推荐 RAII 守护和 std::ref 传引用。

在C++11及以后的标准中,std::thread 提供了简洁、类型安全的方式来创建和管理线程。相比传统的POSIX线程(pthread),它更易于使用,并能与现代C++特性如lambda表达式、函数对象等无缝结合。
使用 std::thread 创建线程非常直接:只需将一个可调用对象(函数、lambda、函数对象)传递给其构造函数即可启动新线程。
示例:通过普通函数创建线程
void hello() {
    std::cout << "Hello from thread!" << std::endl;
}
int main() {
    std::thread t(hello);
    t.join(); // 等待线程结束
    return 0;
}
示例:使用lambda表达式
int main() {
    std::thread t([]() {
        std::cout << "Lambda thread running." << std::endl;
    });
    t.join();
    return 0;
}
注意:传递参数给线程函数需按值或显式使用 std::ref 包装引用
立即学习“C++免费学习笔记(深入)”;
void print_value(int& x) {
    x = 42;
}
int main() {
    int val = 0;
    std::thread t(print_value, std::ref(val)); // 必须用 std::ref
    t.join();
    std::cout << "val is now: " << val << std::endl; // 输出 42
    return 0;
}
每个 std::thread 对象必须在销毁前决定是等待其完成还是将其分离,否则程序会调用 std::terminate() 终止。
常见做法:
- 若需要获取结果或确保线程完成,使用 join()
- 若线程执行长期任务且无需同步,可 detach(),但要小心资源管理和生命周期问题
直接使用裸的 std::thread 可能导致异常安全问题。例如,在创建多个线程时,若中间抛出异常,前面已创建的线程可能未被正确回收。
推荐做法:使用 RAII 技术封装线程管理。
简单线程守卫示例
class ThreadGuard {
    std::thread t;
public:
    explicit ThreadGuard(std::thread t_) : t(std::move(t_)) {}
    ~ThreadGuard() {
        if (t.joinable()) t.join();
    }
    ThreadGuard(const ThreadGuard&) = delete;
    ThreadGuard& operator=(const ThreadGuard&) = delete;
    ThreadGuard(ThreadGuard&&) = default;
};
这样即使发生异常,析构函数也会自动调用 join(),避免资源泄漏。
基本上就这些。std::thread 让多线程编程变得直观,只要注意生命周期和同步问题,就能写出稳定高效的并发代码。
以上就是c++++中如何使用std::thread创建和管理线程_c++ std::thread线程创建与管理的详细内容,更多请关注php中文网其它相关文章!
 
                        
                        c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
 
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号