C++ 的设计模式之 工厂方法加单例

在下面的示例中,我将演示如何创建一个工厂类,该工厂类能够生成四个不同类型的单例对象,每个单例对象都通过单独的工厂方法进行创建。

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

// Singleton base class
class Singleton {
protected:
    Singleton() {}

public:
    Singleton(const Singleton&) = delete;
    Singleton& operator=(const Singleton&) = delete;

    static Singleton& getInstance() {
        static Singleton instance;
        return instance;
    }

    void doSomething() {
        std::cout << "Singleton is doing something." << std::endl;
    }
};

class Singleton1 : public Singleton {
private:
    Singleton1() {}

public:
    static Singleton1& getInstance() {
        static Singleton1 instance;
        return instance;
    }
};

class Singleton2 : public Singleton {
private:
    Singleton2() {}

public:
    static Singleton2& getInstance() {
        static Singleton2 instance;
        return instance;
    }
};

class Singleton3 : public Singleton {
private:
    Singleton3() {}

public:
    static Singleton3& getInstance() {
        static Singleton3 instance;
        return instance;
    }
};

class Singleton4 : public Singleton {
private:
    Singleton4() {}

public:
    static Singleton4& getInstance() {
        static Singleton4 instance;
        return instance;
    }
};

int main() {
    // Using the factory methods to get instances of different singletons
    Singleton1& singleton1 = Singleton1::getInstance();
    Singleton2& singleton2 = Singleton2::getInstance();
    Singleton3& singleton3 = Singleton3::getInstance();
    Singleton4& singleton4 = Singleton4::getInstance();

    // Verify that they are all the same instance
    if (&singleton1 == &singleton2 && &singleton2 == &singleton3 && &singleton3 == &singleton4) {
        std::cout << "All Singletons are the same instance." << std::endl;
    }

    singleton1.doSomething();
    singleton2.doSomething();
    singleton3.doSomething();
    singleton4.doSomething();

    return 0;
}

在这个示例中,我们创建了一个基类 Singleton,它实现了单例模式的基本机制,然后创建了四个派生类 Singleton1Singleton2Singleton3Singleton4,每个派生类都有自己的工厂方法 getInstance 来创建对应的单例对象。

通过这种方式,每个派生类继承了单例的行为,但每个单例对象都是独立的实例。当我们调用工厂方法来获取这些单例对象时,它们确保只有一个实例存在,而且每个工厂方法创建的实例是不同的,即每个单例类都有自己的单例实例。

相关推荐
利刃大大1 小时前
【在线五子棋对战】二、websocket && 服务器搭建
服务器·c++·websocket·网络协议·项目
喜欢吃燃面1 小时前
C++刷题:日期模拟(1)
c++·学习·算法
SHERlocked931 小时前
CPP 从 0 到 1 完成一个支持 future/promise 的 Windows 异步串口通信库
c++·算法·promise
虚拟之2 小时前
36、stringstream
c++
我很好我还能学2 小时前
【面试篇 9】c++生成可执行文件的四个步骤、悬挂指针、define和const区别、c++定义和声明、将引用作为返回值的好处、类的四个缺省函数
开发语言·c++
南岩亦凛汀4 小时前
在Linux下使用wxWidgets进行跨平台GUI开发
c++·跨平台·gui·开源框架·工程实战教程
曦月逸霜4 小时前
第34次CCF-CSP认证真题解析(目标300分做法)
数据结构·c++·算法
蔡蓝4 小时前
设计模式-建造者模式
服务器·设计模式·建造者模式
galaxy_strive4 小时前
绘制饼图详细过程
开发语言·c++·qt
Unpredictable2225 小时前
【VINS-Mono算法深度解析:边缘化策略、初始化与关键技术】
c++·笔记·算法·ubuntu·计算机视觉