当前位置: 首页 > article >正文

类的设计模式——单例、工厂以及建造者模式

1.单例模式

1.1 饿汉模式

单例模式:一个类只能创建一个对象,这个设计模式可以保证系统中该类只有一个实例,并提供一个访问它的全局访问点,该实例被所有程序模块共享。

饿汉模式指在程序初始化时就创建一个唯一的实例对象。适用于多线程环境。他的初始化发生在Singleton Singleton::sig这里。

#include <iostream>
#include <memory>class Singleton{static Singleton sig;
private:Singleton():_data(100){std::cout<<"我被初始化了"<<std::endl;}~Singleton(){}
public:Singleton(const Singleton& sig) = delete;Singleton operator=(const Singleton& sig) = delete;Singleton& getSig(){return sig;}
private:int _data;
};Singleton Singleton::sig;int main()
{return 0;
}

1.2 懒汉模式

懒汉模式第一次使用单例对象的时候创建实例对象。

这里右两份代码,一份是通过锁来完成一份是通过C++11的static特性完成

class Singleton2
{static Singleton2 *sig2;static pthread_mutex_t mutex;private:Singleton2() : _data(100){std::cout << "我被初始化了 2" << std::endl;pthread_mutex_init(&mutex, nullptr);}~Singleton2() { pthread_mutex_destroy(&mutex); }public:Singleton2(const Singleton2 &sig) = delete;Singleton2 operator=(const Singleton2 &sig) = delete;static Singleton2* getSig(){if (sig2 == nullptr){pthread_mutex_lock(&mutex);if (sig2 == nullptr)sig2 = new Singleton2;pthread_mutex_unlock(&mutex);}return sig2;}private:int _data;
};Singleton2 *Singleton2::sig2 = nullptr;
pthread_mutex_t Singleton2::mutex;
template <typename T>
class Singleton
{
private:Singleton() {}~Singleton() {}public:Singleton(const Singleton &) = delete;Singleton &operator=(const Singleton &) = delete;static T &getInstance(){static Singleton _eton;return _eton;}
};

2.工厂模式

工厂模式是一种创建型设计模式,他提供一种创建对象的最佳方式。在工厂模式中,我们创建对象时不会对上层暴露创建逻辑(方便用户操作),而是通过使用一个共同结构来指向新创建的对象,以此实现创建 使用的分离

2.1 简单工厂模式

简单工厂实现由一个工厂对象通过类型决定创建出来指定产品类的实例。

class product_abstract_class{
public:product_abstract_class(){}virtual void show() = 0;
};class product1_class : public product_abstract_class
{
public:product1_class(){}void show() override{std::cout<<"this is product 1"<<std::endl;}
};class product2_class : public product_abstract_class
{
public:product2_class(){}void show() override{std::cout<<"this is product 2"<<std::endl;}
};class factory{
public:static std::shared_ptr<product_abstract_class> generate_instances(const std::string &name){if(name == "product 1") return std::make_shared<product1_class>();else return std::make_shared<product2_class>();}
};

2.2 工厂方法模式

工厂方法模式:在简单工厂模式下新增多个工厂,每个产品对应一个工厂。

class product_abstract_class{
public:product_abstract_class(){}virtual void show() = 0;
};class product1_class : public product_abstract_class
{
public:product1_class(){}void show() override{std::cout<<"this is product 1"<<std::endl;}
};class product2_class : public product_abstract_class
{
public:product2_class(){}void show() override{std::cout<<"this is product 2"<<std::endl;}
};// class factory{
// public:
//     static std::shared_ptr<product_abstract_class> generate_instances(const std::string &name)
//     {
//         if(name == "product 1") return std::make_shared<product1_class>();
//         else return std::make_shared<product2_class>();
//     }
// };class factory_abstract_class{
public:virtual std::shared_ptr<product_abstract_class> create() = 0;    
};class product1_factory : public factory_abstract_class
{
public:std::shared_ptr<product_abstract_class> create() override{return std::make_shared<product1_class>();}
};class product2_factory : public factory_abstract_class
{
public:std::shared_ptr<product_abstract_class> create() override{return std::make_shared<product2_class>();}
};

工厂方法模式每次增加一个产品时,都需要增加一个具体的产品类和工厂类,这会让系统中类的个数成倍增加,在一定程度上增加了系统的耦合度。

而且工厂方法模式会让代码感觉很冗余,但是又必不可少,无法优化

2.3 抽象工厂模式

抽象工厂模式在工厂方法模式中引入了工厂等级结构。

我感觉就是工厂分类,比如香蕉苹果属于水果那么就通过水果工厂生产,狗和猫属于动物就通过动物工厂来生产

class abs_fruit
{
public:abs_fruit(){}virtual void show() = 0;
};class apple_fruit : public abs_fruit
{
public:void show() override{std::cout<<"this is apple"<<std::endl;}
};class banana_fruit : public abs_fruit
{
public:void show() override{std::cout<<"this is banana"<<std::endl;}
};class abs_animal
{
public:abs_animal(){}virtual void show() = 0;
};class cat : public abs_animal
{
public:void show() override{std::cout<<"this is cat"<<std::endl;}
};class dog : public abs_animal
{
public:void show() override{std::cout<<"this is dog"<<std::endl;}
};class abs_factory
{
public:virtual std::shared_ptr<abs_fruit> create_fruit(const std::string &name) = 0;virtual std::shared_ptr<abs_animal> create_animal(const std::string &name) = 0;
};class fruit_factory : public abs_factory
{
public:std::shared_ptr<abs_fruit> create_fruit(const std::string &name) override{if(name == "apple") return std::make_shared<apple_fruit>();else if(name == "banana") return std::make_shared<banana_fruit>();else return std::shared_ptr<abs_fruit>();}virtual std::shared_ptr<abs_animal> create_animal(const std::string &name) override{return std::shared_ptr<abs_animal>();}
};class animal_factory : public abs_factory
{
public:std::shared_ptr<abs_fruit> create_fruit(const std::string &name) override{return std::shared_ptr<abs_fruit>();}virtual std::shared_ptr<abs_animal> create_animal(const std::string &name) override{if(name == "cat") return std::make_shared<cat>();else if(name == "dog") return std::make_shared<dog>();else return std::shared_ptr<abs_animal>();}
};class produce_factory
{
public:static std::shared_ptr<abs_factory> create_factory(const std::string& name){if(name == "fruit") return std::make_shared<fruit_factory>();else if(name == "animal") return std::make_shared<animal_factory>();else return std::shared_ptr<abs_factory>();}
};

3.建造者模式

建造者模式是一种创建型设计模式,使用多个简单的对象一步一步构建一个复杂对象,能够将一个复杂对象的构建与它的表示分离,提供一种创建对象的最佳方式。

主要用于解决对象的构建过于复杂的问题

建造者模式的五个核心类

抽象产品类:用于给具体的产品类继承

具体的产品类:具体的产品对象类

抽象Builder(建造)类:创建一个产品对象所需的各个部件的抽象接口

具体产品的Builder类:实现抽象接口,构建各个部件

指挥者Director类:统一组建过程,提供给调用者使用,通过指挥者来构造产品

//---------------------------------------建造者模式-----------------------------------------------//抽象产品类
class Computer
{
public:using ptr = std::shared_ptr<Computer>; //为std::shared_ptr<Computer>创建类型别名ptr    using等价于typedefComputer(){}void setboard(const std::string &board){_board = board;}void setdisplay(const std::string &display){_display = display;}virtual void setos() = 0;virtual ~Computer(){};
public:std::string to_string(){std::string retstr = "os : "+_os+" "+"board : "+_board+" "+"display : "+_display;return retstr;}
protected:std::string _board;std::string _display;std::string _os;
};//具体产品类
class MacBook : public Computer
{
public:using ptr = std::shared_ptr<MacBook>; void setos() override{ _os = "Max Os X12";}
};//抽象建造者类
class Builder
{
public:using ptr = std::shared_ptr<Builder>;virtual void builder_board(const std::string &board) = 0;virtual void builder_display(const std::string &display) = 0;virtual void builder_os() = 0;
public:virtual Computer::ptr builder() = 0; // 用于建造对象
};//具体产品建造者类
class MacBook_Builder : public Builder
{
public:MacBook_Builder() :_computer(new MacBook()){}
public:void builder_board(const std::string &board){_computer->setboard(board);}void builder_display(const std::string &display){_computer->setdisplay(display);}void builder_os(){_computer->setos();}Computer::ptr builder(){return _computer;}
private:Computer::ptr _computer;
};//指挥者类
class Director
{
public:Director(Builder* builder) :_builder(builder){}void construct(const std::string &board,const std::string &display){_builder->builder_board(board);_builder->builder_display(display);_builder->builder_os();}
private:Builder::ptr _builder;
};int main()
{Builder* dp = new MacBook_Builder;std::shared_ptr<Director> dir(new Director(dp)); dir->construct("英特尔主板","VOC显示器");Computer::ptr tmp = dp->builder();    //这才是我们的目标对象(想要创建的对象)std::cout<<tmp->to_string()<<std::endl;return 0;
}

http://www.lryc.cn/news/2387111.html

相关文章:

  • STM32之看门狗(IWDG)
  • PyTorch实现MLP信用评分模型全流程
  • 语音识别——文本转语音
  • 跟着华为去变革 ——读《常变与长青》有感
  • 图像分割技术的实现与比较分析
  • node.js配置变量
  • Ubuntu+Docker+内网穿透:保姆级教程实现安卓开发环境远程部署
  • 为什么需要清除浮动?清除浮动的方式有哪些?
  • 计算机网络学习20250526
  • ArkUI:鸿蒙应用响应式与组件化开发指南(一)
  • YOLOv11改进 | Neck篇 | 双向特征金字塔网络BiFPN助力YOLOv11有效涨点
  • C/C++的OpenCV 进行轮廓提取
  • 计算机网络总结(物理层,链路层)
  • TIGER - 一个轻量高效的语音分离模型,支持人声伴奏分离、音频说话人分离等 支持50系显卡 本地一键整合包下载
  • yolov8,c++案例汇总
  • 无人机降落伞设计要点难点及原理!
  • 20250526给荣品PRO-RK3566的Android13单独编译boot.img
  • vue3项目动态路由的相关配置踩坑记录
  • git子模块--命令--列表版
  • C++(4)
  • 构建版本没mac上传APP方法
  • 如何解决大模型返回的JSON数据前后加上```的情况
  • 本地处理 + GPU 加速 模糊视频秒变 4K/8K 修复视频老旧素材
  • 服务器异常数据问题解决 工具(tcpdump+wireshark+iptables)
  • 综合实现案例 LVS keepalived mysql 等
  • 【QT】对话框dialog类封装
  • 2025/5/26 学习日记 基本/扩展正则表达式 linux三剑客之grep
  • 【后端高阶面经:消息队列篇】29、Kafka高性能探秘:零拷贝、顺序写与分区并发实战
  • Spring Boot企业级开发五大核心功能与高级扩展实战
  • 在SpringBoot项目中策略模式的使用