std::call_once 解决多线程下初始化竞态问题,确保函数只执行一次。通过与 std::once_flag 配合,实现线程安全的单次初始化,常用于单例模式、全局配置加载等场景,避免显式加锁,提升代码简洁性与安全性。

std::call_once 是 C++ 中用于确保某段代码在多线程环境下只执行一次的机制,常用于线程安全的单次初始化操作。它和 std::once_flag 配合使用,能有效避免竞态条件,保证多个线程同时调用时目标函数仅运行一次。
解决什么问题?
在多线程程序中,某些初始化工作(如全局资源、单例对象构造)必须且只能执行一次。如果多个线程同时判断“是否已初始化”,可能都进入初始化流程,导致重复执行甚至数据损坏。
std::call_once 提供了比手动加锁更简洁、安全的方案:
无需显式使用互斥锁判断状态 保证回调函数绝对只执行一次 性能更好:后续线程直接跳过,无锁竞争
基本用法示例
下面是一个典型的使用场景:
#include #include #include std::once_flag flag;void do_init() { std::cout << "初始化执行一次n";}void thread_func() { std::call_once(flag, do_init);}int main() { std::thread t1(thread_func); std::thread t2(thread_func); std::thread t3(thread_func); t1.join(); t2.join(); t3.join(); return 0;}
尽管三个线程都调用 std::call_once,但 do_init 只会被执行一次,输出也只会出现一次。
立即学习“C++免费学习笔记(深入)”;
适用场景
常见于需要延迟初始化又要求线程安全的场合:
单例模式中的实例创建 全局配置加载 信号处理函数注册 动态库初始化逻辑
例如实现线程安全的单例:
class Singleton {public: static Singleton& get_instance() { std::call_once(init_flag, []() { instance.reset(new Singleton); }); return *instance; }private: Singleton() = default; static std::unique_ptr instance; static std::once_flag init_flag;};
基本上就这些。std::call_once 看似简单,但在构建健壮的多线程程序时非常实用,是现代 C++ 推荐的初始化同步方式之一。不复杂但容易忽略细节,比如 once_flag 不能拷贝、需静态或全局生命周期等。
以上就是c++++中的std::call_once有什么作用_c++线程安全单次初始化机制的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1482284.html
微信扫一扫
支付宝扫一扫