基于SpringBoot设计模式之创建型设计模式·工厂方法模式

介绍

  在 Factory Method模式中,父类决定实例的生成方式,但并不决定所要生成的具体的类,具体的处理全部交给子类负责。这样就可以将生成实例的框架(framework)和实际负责生成实例的类解耦。

开始

架构图

工厂方法设计模式

样例一

定义工厂

public interface Factory {

    /**
     * 工厂可以制作 穿搭衣服
     *
     * @param name 产品名称
     * @return
     */
    WearProduct createProduct(String name);

    /**
     * 获取工厂里面生成的所有产品
     *
     * @return
     */
    List<WearProduct> getProducts();
}

定义具体工厂(上衣、下装)

@Service
@Slf4j
public class ClothesFactory implements Factory {

    // 花花公子工厂,穿搭产品
    private List<WearProduct> wearProducts = new ArrayList<>();

    @Override
    public WearProduct createProduct(String name) {

        // 按照springboot的形式,这里工厂生产完产品,产品是会入库的。
        // 为了快速能了解 工厂方法定义,不做过多的,展示
        WearProduct wearProduct = new ClothesProduct(name);
        wearProducts.add(wearProduct);

        return wearProduct;

    }

    @Override
    public List<WearProduct> getProducts() {
        // 按照springboot的形式,应直接取工厂下面所有的产品。
        // 为了快速能了解 工厂方法定义,这里仅将list输出
        return wearProducts;
    }

}
@Service
@Slf4j
public class TrousersFactory implements Factory {

    // 优衣库工厂,穿搭产品
    private List<WearProduct> wearProducts = new ArrayList<>();

    @Override
    public WearProduct createProduct(String name) {

        // 按照springboot的形式,这里工厂生产完产品,产品是会入库的。
        // 为了快速能了解 工厂方法定义,不做过多的,展示
        WearProduct wearProduct = new TrousersProduct(name);
        wearProducts.add(wearProduct);

        return wearProduct;
    }

    @Override
    public List<WearProduct> getProducts() {
        // 按照springboot的形式,应直接取工厂下面所有的产品。
        // 为了快速能了解 工厂方法定义,这里仅将list输出
        return wearProducts;
    }
}

定义产品

public interface WearProduct {

    /**
     * 展示产品
     */
    void show();

}

定义具体生产产品(上衣、下装)

@Service
@Slf4j
@AllArgsConstructor
@NoArgsConstructor
public class ClothesProduct implements WearProduct {

    private String name;

    @Override
    public void show() {
        System.out.println("这是一个上衣:" + name);
    }
}

@Service
@Slf4j
@AllArgsConstructor
@NoArgsConstructor
public class TrousersProduct implements WearProduct {

    private String name;

    @Override
    public void show() {
        System.out.println("这是一个下装:" + name);
    }
}

测试样例

@Slf4j
@SpringBootTest(classes = FactoryMethodApplication.class)
public class TestFactoryMethod {

    @Resource
    private Map<String, Factory> factoryMap;

    @Test
    public void testWear() {

        Factory clothesFactory = factoryMap.get("clothesFactory");
        Factory trousersFactory = factoryMap.get("trousersFactory");

        clothesFactory.createProduct("潇洒");
        clothesFactory.createProduct("百搭");
        List<WearProduct> clothesFactoryProducts = clothesFactory.getProducts();
        System.out.println("-------------------上衣产品展览---------------");
        for (WearProduct wearProduct : clothesFactoryProducts) {
            wearProduct.show();
        }

        trousersFactory.createProduct("和谐");
        trousersFactory.createProduct("简约");
        List<WearProduct> trousersFactoryProducts = trousersFactory.getProducts();
        System.out.println("-------------------下装产品展览---------------");
        for (WearProduct wearProduct : trousersFactoryProducts) {
            wearProduct.show();
        }

    }


}

总结

优点

  1. 符合单一职责设计原则,每个具体工厂类只负责创建对应的产品。
  2. 新增一种产品时,只需要增加相应的具体产品类和相应的工厂子类即可

缺点

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

与抽象工厂不同点

  • 工厂模式:通常有一个具体的工厂类负责创建某一类产品,客户端直接调用工厂类的方法来获取所需的产品。
  • 抽象工厂模式:往往需要管理多个工厂,同时这多个工厂中的各个工厂,又负责创建不同的产品(零件)
  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值