小言_互联网的博客

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

336人阅读  评论(0)

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

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


   
  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—————

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

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

转载:https://blog.csdn.net/bjweimengshu/article/details/108459337
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场