设计模式 抽象工厂方法模式

定义与特点

工厂方法模式(FactoryMethod),定义一个创建产品对象的工厂接口,让工厂子类决定实例化那一个产品类。工厂方法使一个类的实例化延迟到其子类。

我们把被创建的对象称为"产品",把创建产品的对象称为"工厂"。

如果要创建的产品不多,只要一个工厂类就可以完成,这种模式叫"简单工厂模式",它不属于 GoF 的 23 种经典设计模式,它的缺点是增加新产品时会违背"开闭原则"(可以通过反射克服该缺点)。

工厂方法模式核心组件

工厂方法模式是在简单工厂模式上的改进,主要包含如下几个角色及组件

工厂方法模式核心组件
  • 抽象工厂(Creator):整个工厂模式的核心角色,它与应用无关,主要在创建模式中规范和产品对应的工厂对象的标准化定义。
  • 具体工厂(Concrete Creator):实现了抽象工厂的具体工厂类,该类型是和应用直接交互的具体实现类,在应用程序中调用,用于创建产品对象。
  • 抽象产品(Product):工厂方法模式创建的所有类型的超级父类,该类型和具体业务有关,用于规范工厂方法模式中创建的方法对象具备的公共特征行为。
  • 具体产品(Concrete Product):该类型实现了抽象产品 父类,是工厂方法模式中具体创建的实例对象。
工厂方法模式优缺点
优点:

在简单工厂模式上的改进,核心工厂类不再负责所有产品的构建,而是将具体的工作交给子类进行实现,不再接触和业务相关的具体细节,如此进一步抽象的结果,最直接的作用就是在满足OCP原则的基础上实现了功能的扩展。

缺点:

软件的水平功能扩展已经非常可观,但是对于新功能扩展,灵活性上稍有欠缺,在横向扩展时如果出现新的业务逻辑就需要更改原有的工厂类型代码予以满足了。

第一种方式
java 复制代码
// 抽象方法
public interface SimpleFactory<T> {
    /**
     * 获取具体产品实例的方法
     * @return 返回创建的实例对象
     */
    T product();
}
// 实体对象
public interface Product {
    /**
     * 产品类型的公共方法
     * @return 返回产品信息
     */
    String getInformation();
}

public class Test1Product implements  Product{
    @Override
    public String getInformation() {
        return "测试 Test1 product 信息";
    }
}

public class Test2Product implements Product{

    @Override
    public String getInformation() {
        return "测试 Test2 Product 信息";
    }
}

public class Test1Factory implements SimpleFactory<Product>{
    @Override
    public Product product() {
        return new Test1Product();
    }
}

public class Test2Factory implements SimpleFactory<Product>{
    @Override
    public Product product() {
        return new Test2Product();
    }
}

Test1Factory test1Factory = new Test1Factory();
Product test1product = test1Factory.product();
System.out.println(test1product.getInformation());
Test2Factory test2Factory = new Test2Factory();
Product test2product = test2Factory.product();
System.out.println(test2product.getInformation());
第二种方式
java 复制代码
package simpleFactoryModel;

public class Simp1Factory {
    private static Product product;

    public static void setProduct(Product product) {
        if(product != null){
            Simp1Factory.product = null;
        }
    }

    public static Product getProduct(String text) {
        if (product == null) {
            // 每次锁定一个对象
            synchronized (Simp1Factory.class) {
                if("test1".equals(text))
                {
                    product = new Test1Product();
                }
                if("test2".equals(text))
                {
                    product = new Test2Product();
                }
            }
        }
        return product;
    }
}

Simp1Factory simp1Factory = new Simp1Factory();
Product test1 = Simp1Factory.getProduct("test1");
Simp1Factory.setProduct(test1);
Product test2 = Simp1Factory.getProduct("test2");
System.out.println(test1.getInformation());
System.out.println(test2.getInformation());
相关推荐
Pkmer2 小时前
古法编程: 适配器模式
java·设计模式
灰子学技术18 小时前
Envoy 使用的设计模式技术文档
设计模式
Carl_奕然1 天前
【智能体】Agent的四种设计模式之:ReAct
人工智能·设计模式·语言模型
二哈赛车手1 天前
新人笔记---多策略搭建策略执行链实现RAG检索后过滤
java·笔记·spring·设计模式·ai·策略模式
楼田莉子1 天前
仿Muduo的高并发服务器:Channel模块与Poller模块
linux·服务器·c++·学习·设计模式
geovindu2 天前
go: Strategy Pattern
开发语言·设计模式·golang·策略模式
嵌入式学习_force2 天前
02_state
设计模式·蓝牙
qcx232 天前
Warp源码深度解析(七):Token预算策略——双轨计费、上下文溢出与摘要压缩
人工智能·设计模式·rust·wrap
Cosolar3 天前
提示词工程面试题系列 - Zero-Shot Prompting 和 Few-Shot Prompting 的核心区别是什么?
人工智能·设计模式·架构
geovindu3 天前
go:Template Method Pattern
开发语言·后端·设计模式·golang·模板方法模式