每日设计模式之工厂方法模式

工厂方法模式定义了创建对象的接口,让子类决定实例化哪类。此模式隐藏了产品实例化细节,允许系统在不修改客户端代码的情况下扩展。本文详细介绍了工厂方法模式的实现,包括抽象产品、具体产品、抽象工厂和具体工厂的概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

工厂方法模式

工厂方法模式(Factory Method Pattern):定义一个用于创建对象的接口,让子类决定将哪一个 类实例化。工厂方法模式让一个类的实例化延迟到其子类。工厂方法模式又简称为工厂模式 (Factory Pattern),又可称作虚拟构造器模式(Virtual Constructor Pattern)或多态工厂模式 (Polymorphic Factory Pattern)。工厂方法模式是一种类创建型模式

//抽象产品
public interface Product {
    public void create();
}
//具体产品A
public class ConcreteProductA implements Product {
    @Override
    public void create() {
        System.out.println("ConcreteProductA was created");
    }
}
//具体产品A
public class ConcreteProductB implements Product {
    @Override
    public void create() {
        System.out.println("ConcreteProductB was created");
    }
}
//抽象工厂
public interface Factory {
    Product createProduct();
}
//抽象工厂A 对应的是具体产品A
public class ConcreteFactoryA implements Factory {

    @Override
    public Product createProduct() {

        return new ConcreteProductA();
    }
}
//抽象工厂B 对应的是具体产品B
public class ConcreteFactoryB implements Factory {
    @Override
    public Product createProduct() {
        return new ConcreteProductB();
    }
}
//下面factoryStr可以配置到配置文件yml等中,可以对客户端代码进行修改,不再直接使用new关键字来创建具体的工厂类
public class FactoryMethodClient {
    public static void main(String[] args) {
        String factoryStr="org.timkey.design.factoryMethod.ConcreteFactoryB";
        Factory factory =null;
        try {
            Class c = Class.forName(factoryStr);
            factory = (Factory)c.newInstance();
        } catch (Exception e) {
            System.out.println("exception error");
            System.out.println(e.getMessage());
        }
        Product product = factory.createProduct();
        product.create();
    }
}

优点:

  1. 在工厂方法模式中,工厂方法用来创建客户所需要的产品,同时还向客户隐藏了哪种具体 产品类将被实例化这一细节,用户只需要关心所需产品对应的工厂,无须关心创建细节,甚 至无须知道具体产品类的类名。

  2. 基于工厂角色和产品角色的多态性设计是工厂方法模式的关键。它能够让工厂可以自主确 定创建何种产品对象,而如何创建这个对象的细节则完全封装在具体工厂内部。工厂方法模 式之所以又被称为多态工厂模式,就正是因为所有的具体工厂类都具有同一抽象父类

  3. 使用工厂方法模式的另一个优点是在系统中加入新产品时,无须修改抽象工厂和抽象产品 提供的接口,无须修改客户端,也无须修改其他的具体工厂和具体产品,而只要添加一个具 体工厂和具体产品就可以了,这样,系统的可扩展性也就变得非常好,完全符合“开闭原则”

缺点:

  1. 在添加新产品时,需要编写新的具体产品类,而且还要提供与之对应的具体工厂类,系统 中类的个数将成对增加,在一定程度上增加了系统的复杂度,有更多的类需要编译和运行, 会给系统带来一些额外的开销

  2. 由于考虑到系统的可扩展性,需要引入抽象层,在客户端代码中均使用抽象层进行定义, 增加了系统的抽象性和理解难度,且在实现时可能需要用到配置文件中读取配置、反射等技术,增加了系统 的实现难度

适用场景:

  1. 客户端不知道它所需要的对象的类。在工厂方法模式中,客户端不需要知道具体产品类的 类名,只需要知道所对应的工厂即可,具体的产品对象由具体工厂类创建,可将具体工厂类 的类名存储在配置文件或数据库中

  2. 抽象工厂类通过其子类来指定创建哪个对象。在工厂方法模式中,对于抽象工厂类只需要 提供一个创建产品的接口,而由其子类来确定具体要创建的对象,利用面向对象的多态性和 里氏代换原则,在程序运行时,子类对象将覆盖父类对象,从而使得系统更容易扩展

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值