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

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

相关推荐
top_designer8 分钟前
告别“静态”VI手册:InDesign与AE打造可交互的动态品牌规范
设计模式·pdf·交互·vi·工作流·after effects·indesign
_码力全开_12 分钟前
P1005 [NOIP 2007 提高组] 矩阵取数游戏
java·c语言·c++·python·算法·矩阵·go
孤廖42 分钟前
吃透 C++ 栈和队列:stack/queue/priority_queue 用法 + 模拟 + STL 标准实现对比
java·开发语言·数据结构·c++·人工智能·深度学习·算法
非凡的世界1 小时前
深入理解 PHP 框架里的设计模式
开发语言·设计模式·php
小龙报1 小时前
《算法通关指南---C++编程篇(3)》
开发语言·c++·算法·visualstudio·学习方法·visual studio
一叶飘零_sweeeet1 小时前
深入 Spring 内核:解密 15 种设计模式的实战应用与底层实现
java·spring·设计模式
Mr_WangAndy2 小时前
C++设计模式_行为型模式_状态模式State
c++·设计模式·状态模式
郝学胜-神的一滴2 小时前
Effective STL 第5条:区间成员函数优先于单元素成员函数
开发语言·c++·程序人生·stl·软件工程
mit6.8242 小时前
c++|表达最值的更好方法|clamp
c++
涤生z3 小时前
list.
开发语言·数据结构·c++·学习·算法·list