std::thread创建多线程需传入可调用对象并显式管理生命周期,必须调用join()或detach()避免析构时终止程序,共享数据需用mutex、atomic或thread_local防护。

用 std::thread 创建多线程很简单,核心是把一个可调用对象(函数、lambda、绑定表达式等)传给 std::thread 构造函数,它就会在新线程中执行。但必须注意线程生命周期管理,否则程序可能崩溃或未定义行为。
创建线程的几种常见方式
你可以传入普通函数、带参数的函数、lambda 表达式,甚至成员函数:
- 普通函数:
std::thread t(func); - 带参数的函数:
std::thread t(func, arg1, arg2);(参数按值拷贝,如需引用要用std::ref(x)) - lambda:
std::thread t([]{ do_something(); }); - 类成员函数:
std::thread t(&MyClass::method, &obj, arg);(第一个参数是成员函数指针,第二个是对象指针或引用)
必须显式处理线程结束
std::thread 对象析构时,如果仍关联着活跃线程,会调用 std::terminate() 直接终止整个程序。所以你必须在析构前决定它是 等待完成 还是 分离运行:
-
t.join();—— 当前线程阻塞,直到t执行完。适合需要结果或同步的场景。 -
t.detach();—— 把线程和std::thread对象解绑,线程后台运行,资源由系统回收。适合“发射即忘”的任务(如日志上报),但不能再控制或等待它。
别忘了:join() 只能调用一次;已 join 或 detach 的线程对象,再调用会抛出异常。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~