一天一个设计模式---工厂方法

概念

工厂模式是一种创建型设计模式,其主要目标是提供一个统一的接口来创建对象,而不必指定其具体类。工厂模式将对象的实例化过程抽象出来,使得客户端代码不需要知道实际创建的具体类,只需通过工厂接口或方法来获取所需的对象。

具体内容

工厂模式通常包括以下几个角色:

  1. 抽象产品(Abstract Product): 定义了产品的接口,具体的产品类必须实现这个接口。
  2. 具体产品(Concrete Product): 实现了抽象产品接口的具体类,是工厂模式真正创建的对象。
  3. 抽象工厂(Abstract Factory): 声明了创建产品的接口,通常包括一个或多个方法,每个方法对应一个具体产品的创建。
  4. 具体工厂(Concrete Factory): 实现了抽象工厂接口,负责实际创建具体产品的对象。

类结构图

适用场景

工厂模式的优点包括:

  • 封装对象的创建过程: 客户端不需要知道对象的具体创建方式,只需通过工厂接口获取所需对象,降低了耦合性。
  • 易于扩展: 如果需要添加新的产品类,只需扩展抽象产品和具体产品,同时创建新的具体工厂即可,不需要修改客户端代码。
  • 符合开闭原则: 对扩展开放,对修改关闭。可以轻松地添加新产品类,而不影响已有代码。

工厂模式的缺点包括:

  • 增加了类的数量: 引入了抽象工厂和具体工厂,增加了类的数量,可能使代码结构复杂。
  • 需要一定的抽象能力: 需要正确地定义抽象产品和工厂接口,如果定义不合理,可能会导致系统难以理解和维护。

实现

JS 复制代码
// 抽象产品
class Product {
  constructor(name) {
    this.name = name;
  }
}

// 具体产品A
class ConcreteProductA extends Product {
  constructor() {
    super('ProductA');
  }
}

// 具体产品B
class ConcreteProductB extends Product {
  constructor() {
    super('ProductB');
  }
}

// 抽象工厂
class Factory {
  createProduct() {
    // 定义创建产品的接口
  }
}

// 具体工厂A
class ConcreteFactoryA extends Factory {
  createProduct() {
    return new ConcreteProductA();
  }
}

// 具体工厂B
class ConcreteFactoryB extends Factory {
  createProduct() {
    return new ConcreteProductB();
  }
}

// 客户端代码
const factoryA = new ConcreteFactoryA();
const productA = factoryA.createProduct();
console.log(productA.name); // 输出: ProductA

const factoryB = new ConcreteFactoryB();
const productB = factoryB.createProduct();
console.log(productB.name); // 输出: ProductB
相关推荐
小程故事多_804 小时前
从Claude Code源码中,拆解13个可直接复用的Agentic Harness设计模式(生产级实战解析)
人工智能·设计模式·智能体·claude code·harness
踩着两条虫9 小时前
VTJ 平台六大设计模式落地实战指南
开发语言·前端·人工智能·低代码·设计模式·重构·架构
石油人单挑所有11 小时前
基于多设计模式下的同步&异步日志系统测试报告
服务器·c++·vscode·设计模式
geovindu14 小时前
go:Decorator Pattern
开发语言·设计模式·golang·装饰器模式
ximu_polaris14 小时前
设计模式(C++)-行为型模式-观察者模式
c++·观察者模式·设计模式
Lands1 天前
推荐一下配合agent开发的工具
设计模式·agent
不才小强1 天前
行为型设计模式
设计模式
ximu_polaris1 天前
设计模式(C++)-结构型模式-享元模式
c++·设计模式·享元模式
geovindu1 天前
go: Facade Pattern
设计模式·golang·外观模式
旷世奇才李先生2 天前
React 18\+TypeScript实战: hooks封装与组件设计模式
react.js·设计模式·typescript