设计模式-工厂方法模式

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

     工厂方法模式(Factory Method Pattern)是一种常用的类创建型设计模式,它属于对象的创建型模式,主要用来封装对象的创建过程。在该模式中,一个抽象工厂定义了一个接口用于创建产品对象,但实际的实例化延迟到子类中进行,也就是说,具体的产品是由其对应的工厂来创建的。

角色和职责:

1 抽象工厂(Abstract Factory)

  • 定义一个创建产品接口,创建产品工厂方法。
  • 通常是一个抽象类或接口,带有一个抽象方法,该方法返回一个抽象产品类型。

2 具体工厂(Concrete Factory)

  • 实现抽象工厂中定义的工厂方法,负责生产具体的产品对象。
  • 根据传入的参数或其他条件决定创建哪种具体产品对象。

3 抽象产品(Abstract Product)

  • 描述所有可能被创建的产品的公共接口。
  • 可以是一个抽象类或接口,为各种具体产品定义了共同的方法。

4 具体产品(Concrete Product)

  • 是抽象产品接口的具体实现类。
  • 具体工厂创建并返回的具体对象类型。

优点:

  • 符合开闭原则,增加新的产品时,无需修改已有代码,只需新增一个具体的工厂类和产品类即可。
  • 抽象了对象的创建过程,使得系统具有更好的灵活性和可扩展性。
  • 将对象的创建与使用分离,降低了模块间的耦合度。

缺点:

  • 当需要增加新产品时,必须提供一个与之对应的新工厂,这可能导致类数量增多,增加了系统的复杂性。
  • 如果产品之间的差异较大,可能会导致工厂类变得复杂且难以维护。

应用场景:

  • 当一个类不知道它所必须创建的对象的确切类时。
  • 当一个类希望由它的子类来指定它所创建的对象类时。
  • 当构造过程必须使用客户程序提供的信息时。

代码例子:

// 抽象产品
public abstract class Coffee {
    public abstract void brew();
}

// 具体产品
public class Americano extends Coffee {
    @Override
    public void brew() {
        // 美式咖啡冲泡逻辑
    }
}

public class Latte extends Coffee {
    @Override
    public void brew() {
        // 拿铁咖啡冲泡逻辑
    }
}

// 抽象工厂
public abstract class CoffeeFactory {
    public abstract Coffee makeCoffee();
}

// 具体工厂
public class AmericanoFactory extends CoffeeFactory {
    @Override
    public Coffee makeCoffee() {
        return new Americano();
    }
}

public class LatteFactory extends CoffeeFactory {
    @Override
    public Coffee makeCoffee() {
        return new Latte();
    }
}

在上面的代码中,CoffeeFactory是抽象工厂,AmericanoFactoryLatteFactory是具体工厂,而AmericanoLatte是具体产品。通过不同的工厂可以创建不同类型的咖啡产品。

  • 12
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qyhua

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值