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 来创建对应的单例对象。

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

相关推荐
嘿BRE7 分钟前
【C++】几个基本容器的模拟实现(string,vector,list,stack,queue,priority_queue)
c++
ö Constancy1 小时前
c++ 笔记
开发语言·c++
fengbizhe1 小时前
笔试-笔记2
c++·笔记
徐霞客3201 小时前
Qt入门1——认识Qt的几个常用头文件和常用函数
开发语言·c++·笔记·qt
fpcc1 小时前
redis6.0之后的多线程版本的问题
c++·redis
螺旋天光极锐斩空闪壹式!2 小时前
自制游戏:监狱逃亡
c++·游戏
工业3D_大熊3 小时前
3D可视化引擎HOOPS Luminate场景图详解:形状的创建、销毁与管理
java·c++·3d·docker·c#·制造·数据可视化
暮色_年华3 小时前
Modern Effective C++ Item 11:优先考虑使用deleted函数而非使用未定义的私有声明
c++
流星白龙3 小时前
【C++习题】10.反转字符串中的单词 lll
开发语言·c++
小白不太白9503 小时前
设计模式之 模板方法模式
java·设计模式·模板方法模式