C++ 并发专题 - 线程安全的单例模式

一:概述:

在C++编程中,call_once 是一种机制,用于确保某个函数或代码段在多线程环境下仅被调用一次。这种机制常用于初始化资源、配置全局变量或执行只需执行一次的逻辑。在 C++11 标准中,std::call_once 是由标准库提供的工具,它与 std::once_flag 配合使用,能够实现线程安全的一次性初始化。

二:工作原理:

  1. std::once_flag:是一个标志,标识某段代码是否已经被调用过。
  2. std::call_once:接收一个 std::once_flag 和一个函数/可调用对象,只在第一次调用时执行,后续调用直接返回

三:特点和优点

  1. 线程安全:即使多个线程同时调用,std::call_once 也保证函数只执行一次。
  2. 性能优化:相比手写的双重检查锁机制,std::call_once 更简洁、易用且高效。
  3. 无锁实现:在实现细节上,现代标准库可能会使用无锁算法,减少锁竞争的开销。

四:例子(线程安全的单例模式)

cpp 复制代码
#include <iostream>
#include <mutex>

// 单例类 MySingleton
class MySingleton {

private:
    static std::once_flag initInstanceFlag; // 标志位,确保初始化函数只调用一次
    static MySingleton * instance;         // 指向单例实例的静态指针

    // 私有化构造函数和析构函数,防止外部创建或销毁实例
    MySingleton() = default;
    ~MySingleton() = default;

public:
    // 删除拷贝构造函数和赋值运算符,防止复制或赋值单例对象
    MySingleton(const MySingleton&) = delete;
    MySingleton& operator = (const MySingleton&) = delete;

    // 获取单例实例的方法
    static MySingleton * getInstance() {
        // 使用 std::call_once 确保 initSingleton 只被调用一次
        std::call_once(initInstanceFlag, MySingleton::initSingleton);
        return instance;
    }

    // 初始化单例实例的静态方法
    static void initSingleton() {
        instance = new MySingleton();
    }
};

// 定义静态成员变量,初始化为空
MySingleton * MySingleton::instance = nullptr;
std::once_flag MySingleton::initInstanceFlag;

int main() {
    // 输出空行,仅用于美化输出
    std::cout << '\n';

    // 第一次调用 getInstance 时,初始化单例对象
    std::cout << "MySingleton::getInstance(): " << MySingleton::getInstance() << '\n';

    // 第二次调用 getInstance,不会重新初始化,返回同一个实例
    std::cout << "MySingleton::getInstance(): " << MySingleton::getInstance() << '\n';

    std::cout << '\n'; // 输出空行,美化输出
}
相关推荐
oioihoii11 分钟前
C++23新特性详解:迈向更现代化的C++
开发语言·c++·c++23
JoshuaGraham34 分钟前
Java 并发-newFixedThreadPool
java·开发语言
darkchink37 分钟前
[LevelDB]Block系统内幕解析-元数据块(Meta Block)&元数据索引块(MetaIndex Block)&索引块(Index Block)
android·java·服务器·c语言·数据库·c++·分布式
iFlyCai44 分钟前
Xcode警报“Ignoring duplicate libraries: ‘-lc++’” 警报
开发语言·c++
Freak嵌入式1 小时前
一文速通 Python 并行计算:06 Python 多线程编程-基于队列进行通信
开发语言·python·多线程·面向对象·并行计算
无名之逆1 小时前
[特殊字符] 超轻高性能的 Rust HTTP 服务器 —— Hyperlane [特殊字符][特殊字符]
java·服务器·开发语言·前端·网络·http·rust
xiecoding.cn1 小时前
Sublime Text使用教程(用Sublime Text编写C语言程序)
c语言·c++·青少年编程·编辑器·sublime text
DXM05211 小时前
牟乃夏《ArcGIS Engine地理信息系统开发教程》学习笔记1
开发语言·经验分享·笔记·学习·arcgis·c#·arcgis engine
熊猫鹏-梓潼1 小时前
Swift Programming All in One苹果程序开发自学之路
开发语言·ios·swift
archko1 小时前
telophoto源码查看记录 二
java·开发语言