漫话:设计模式之 “工厂模式”

—————  第二天  —————

————————————


    
    
  1. ClassA a =  new ClassA();
  2. ClassB b =  new ClassB();

假设我们的业务代码当中,有一个被广泛引用的“口罩类”,这个类实例需要在许多地方被创建和初始化,而初始化的代码也比较复杂。


    
    
  1. public class Mask {
  2.      //构造函数
  3.     public Mask(){
  4.          // .....
  5.          // 100行初始化代码
  6.     }
  7. }

针对这种情况,我们可以构建一个“口罩工厂”专门负责创建口罩对象,把口罩的初始化代码迁移到工厂类的创建方法当中:


    
    
  1. public class MaskFactory {
  2.     public Mask createMask() {
  3.         Mask mask =  new Mask();
  4.          // .....
  5.          // 100行初始化代码
  6.          return mask;
  7.     }
  8. }

假设口罩类只是一个抽象接口,有两个子类“高端口罩”和“低端口罩”分别实现了这个接口:


    
    
  1. public  interface IMask {
  2.     void show();
  3. }
  4. public class HighEndMask implements IMask {
  5.     @Override
  6.     public void show() {
  7.         System.out. println( "我是高端口罩");
  8.     }
  9. }
  10. public class LowEndMask implements IMask {
  11.     @Override
  12.     public void show(){
  13.         System.out. println( "我的低端口罩");
  14.     }
  15. }

那么口罩工厂该如何创建这两种类型的口罩呢?

很简单,在创建方法中传入参数(这里的参数是type),根据参数来做条件判断,决定创建什么样的口罩:


    
    
  1. public class MaskFactory{
  2.     public IMask createMask(String  type) {
  3.         IMask mask = null;
  4.          if( "高端口罩".equals( type)){
  5.             mask =  new HighEndMask();
  6.              // .....
  7.              // HighEndMask的100行初始化代码
  8.         } else  if( "低端口罩".equals( type)){
  9.             mask =   new LowEndMask();
  10.              // .....
  11.              // LowEndMask的100行初始化代码
  12.         }
  13.          return mask;
  14.     }
  15. }

在客户端,想要创建什么样的口罩对象,只需传入对应的类型名称:


    
    
  1. public class Test {
  2.     public static void main(String[] args) {
  3.         MaskFactory factory =  new MaskFactory();
  4.         IMask maskA = factory.createMask( "高端口罩");
  5.         IMask maskB = factory.createMask( "低端口罩");
  6.         maskA.show();
  7.         maskB.show();
  8.     }
  9. }

(注:所谓面向对象的开放-封闭原则,就是在程序中对“扩展”开放,对“修改”封闭。如果每次业务改动都要增加新的if-else,就涉及对旧有代码的修改,不但容易出错,可读性也不好。)

让我们根据这个思路,重构一下工厂类的逻辑:


    
    
  1. public  interface IMaskFactory {
  2.     IMask createMask();
  3. }
  4. public class HighEndFactory implements IMaskFactory{
  5.     @Override
  6.     public IMask createMask() {
  7.         IMask mask =   new HighEndMask();
  8.          // .....
  9.          // HighEndMask的100行初始化代码
  10.          return mask;
  11.     }
  12. }
  13. public class LowEndFactory implements IMaskFactory{
  14.     @Override
  15.     public IMask createMask() {
  16.         IMask mask =   new LowEndMask();
  17.          // .....
  18.          //  LowEndMask的100行初始化代码
  19.          return mask;
  20.     }
  21. }

在代码中,工厂类变成了抽象的接口,高端口罩工厂和低端口罩工厂这两个子类分别实现了该接口。

在客户端,想要创建什么样的口罩对象,只需实例化不同的工厂子类,调用相同的创建方法,无需再传入参数:


    
    
  1. public class Test {
  2.     public static void main(String[] args) {
  3.         IMaskFactory factoryA =  new LowEndFactory();
  4.         IMaskFactory factoryB =  new HighEndFactory();
  5.         IMask maskA = factoryA.createMask();
  6.         IMask maskB = factoryB.createMask();
  7.         maskA.show();
  8.         maskB.show();
  9.     }
  10. }

—————END—————

喜欢本文的朋友,欢迎关注公众号 程序员小灰,收看更多精彩内容

点个[在看],是对小灰最大的支持!

    
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值