设计模式之——简单工厂模式

上图为简单工厂模式的架构图。

1,产品(Product) 将会对接口进行声明。

2,具体产品(Concrete Products)是产品接口的不同实现。

3,创建者(Concrete Creators)将会重写基础工厂方法,使其返回不同类型的产品。

工厂模式在跨平台的对话框的应用:

在不同的操作系统下,UI组件外观或许略有不同,但其功能保持一致。Windows系统中的按钮

在Linux系统中仍是按钮,如果用工厂方法,就不需要为每种操作系统重写对话框逻辑。

简单工厂模式的理念:

1,对扩展开放,对修改关闭,当业务需要扩展或修改时,尽可能少的修改代码,以增加代码来代 替修改

2,依赖倒置,避免依赖具体的类,尽量依赖抽象的类,具体类虚继承抽象类 以此实现间接依赖。

可以避免创建者和具体产品之间的紧密耦合。

3,单一职责原则。将产品创建代码放在程序的单一位置,从而使得代码更容易维护。

4,针对接口编程,不要针对实现编程

【缺点】:应用工厂方法模式需要引入许多新的子类,代码可能会因此变得更复杂,最好的情况是

将该模式引入创建者类的现有层次结构中。

#include<iostream>
#include<fstream>
using namespace std;

//交通方式
class Transport
{
public:
virtual void doworking() = 0;
};

//卡车运输
class Truck : public Transport
{
public:
virtual void doworking()
{
cout << "卡车运输" << endl;
}
};

//轮船运输
class Ship : public Transport
{
virtual void doworking()
{
cout << "轮船运输" << endl;
}
};

//物流
class Logistics
{
public:
virtual ~Logistics() {}
virtual Transport* factory() = 0;
void dosomething()
{
Transport* tran = factory();
tran->doworking();
}
};

//陆上物流
class TruckLogistics : public Logistics
{
public:
virtual ~TruckLogistics() {}
virtual Transport* factory()
{
return new Truck;
}
};

//海上物流
class ShipLogistics : public Logistics
{
public:
virtual ~ShipLogistics() {}
virtual Transport* factory()
{
return new Ship;
}
};

int main()
{
Logistics* log = new ShipLogistics();
log->dosomething();
}

相关推荐
geovindu6 小时前
python: Functional Options Pattern
开发语言·后端·python·设计模式·惯用法模式·函数式选项模式
Kel11 小时前
Pregel 为什么会成为LangGraph编排的心脏
人工智能·设计模式·架构
会周易的程序员14 小时前
microLog 后端开发指南
开发语言·c++·物联网·设计模式·日志·iot·aiot
geovindu16 小时前
go: Functional Options Pattern
开发语言·后端·设计模式·golang·函数式选项模式’·惯用法模式
Kel1 天前
MCP 传输链路全链路拆解:从字节流到协议栈的四层架构之旅
人工智能·设计模式·架构
atunet1 天前
关于算法设计模式的演化与编程范式变迁的技术7
算法·设计模式
geovindu2 天前
go:Timing Functions Pattern
开发语言·后端·设计模式·golang·计时函数模式·性能分析模式
咖啡八杯3 天前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
槑有老呆3 天前
从 Prompt Engineering 到 Harness Engineering:AI 编程的下一次跃迁
设计模式
HjhIron4 天前
从Prompt到Context:大模型应用开发的范式转移
设计模式·aigc·ai编程