设计模式--工厂模式

1.工厂模式简介

工厂模式分为简单工厂模式工厂方法模式抽象工厂模式 ,它们都属于设计模式中的创建型模式。其主要功能都
是帮助我们把对象的实例化部分抽取了出来,目的是降低系统中代码耦合度,并且增强了系统的扩展性。本文对这
三种模式进行了介绍并且分析它们之间的区别。
下面看下简单工厂模式的实现步骤:

1.1简单工厂模式

简单工厂模式最大的优点在于实现对象的创建和对象的使用分离将对象的创建交给专门的工厂类负责,但是其最
大的缺点在于工厂类不够灵活,增加新的具体产品需要修改工厂类的判断逻辑代码,而且产品较多时,工厂方法代
码将会非常复杂。

step01-创建汽车接口

包含一个run()方法

 public interface Car {
  /*** 汽车运行的接口方法 */
   void run(); 
   }
steo02-创建三个汽车实现类

汽车类实现汽车接口,并重写run()方法

public class Benz implements Car {
@Autowired
    public void run() {
        System.out.println("奔驰 is running!");
    }
}
public class Bike implements Car {
@Autowired
    public void run() {
        System.out.println("我只有自行车!");
    }
}
public class Bmw implements Car {
@Autowired
    public void run() {
        System.out.println("宝马 is running!");
    }
}
step03-构造汽车工厂

汽车工厂包含一个创建汽车的getCar()方法,方法内部根据传入的参数,进行对象的创建

public class CarFactory {
    public static Car getCar(String type){
        if("benz".equalsIgnoreCase(type)){
            //其中可能有很复杂的操作 
            return new Benz();
        } else if("bmw".equalsIgnoreCase(type)){
            //其中可能有很复杂的操作
            return new Bmw(); 
        }else {
            return new Bike(); 
        } 
    } 
}
step04-测试简单工厂

(1)先看下不使用工厂模式时,创建对象及调用方法的方式:

public class Client {
    public static void main(String[] args) {
        Car bmw = new Bmw();
        bmw.run();
        Car benz = new Benz(); 
        benz.run();
    }
}

(2)使用简单工厂模式时,调用对象方法的方式:

//使用简单工厂方法,获取对象
public class simpleFactoryDemo{
    public static void main(String[] args) {
        Car bmw = CarFactory.getCar("bmw"); 
        bmw.run();
        Car benz = CarFactory.getCar("benz");
        benz.run(); 
    } 
}

注意:
1.可能有人会问,使用简单工厂模式,代码量比不使用工厂模式要复杂为什么还要使用呢?
这个问题,其实是因为这个示例比较简单,试想,在car接口的方法有N个时(一个汽车可能会有很多的方法),这样在调用的时候就需要每个都set()方法进行调用,代码冗余就很明显了。
2.在工厂类中的getCar()方法内部,传值不仅仅可以传String类型的参数,也可以传Class类,如下代码:

public class CarFactory {
    public static Car getCar(Class clazz){
        if("benz".equalsIgnoreCase(clazz.getName())){
            //其中可能有很复杂的操作
            return new Benz();
        } else if("bmw".equalsIgnoreCase(clazz.getName())){
            //其中可能有很复杂的操作
            return new Bmw();
        }else {
            return new Bike();
        }
    }
}
//参数为类
public class simpleFactoryDemo{
    public static void main(String[] args) {
        Car bmw = CarFactory.getCar(Bmw.class); 
        bmw.run();
        Car benz = CarFactory.getCar(Benz.class);
        benz.run(); 
    } 
}

1.2工厂方法模式

java开发中要遵循开闭原则,如果将来有一天我想增加一个新的车,那么必须修改CarFactory工厂类,就不太灵活。
解决方案是使用工厂方法模式。

何为工厂方法模式?

拿创建汽车的案例来讲,当有一天需要增加一个新车时,比如Audi,简单工厂模式中需要在carFactory工厂类的getCar()方法内部增加一个Audi的判断进行对象的创建。而工厂方法模式,顾名思义,将原有的几个车公用一个工厂类,改为每个车都有自己的工厂类,这样,在新增车辆Audi时,只需要新增一个Audi自己的工厂类,进而进行对象的创建即可。
下面看下具体步骤:

step01-创建工厂的抽象接口

首先,将原有的carFactory工厂类抽象出一个工厂接口

public interface Factory {
    /*** 统一的创建方法 * @return */ 
    Car create(); 
}
step02-针对每一个产品构建一个工厂方法

BenzFactoryl类

public class BenzFactory implements Factory {
    public Car create() {
        //中间省略一万行代码 
         return new Benz(); 
    } 
}

新增Audi时

public class AudiFactory implements Factory {
    public Car create() {
        //中间省略一万行代码 
         return new Audi(); 
    } 
}
step03-测试工厂方法模式
public class methodFactoryDemo{
    public static void main(String[] args) {
        //先实例化工厂类
        Factory benzFactory = new BenzFactory(); 
        //调用工厂类中creat()方法创建对象
        Car benz = benzFactory.create(); 
        //调用run()方法
        benz.run(); 
        
        Factory audiFactory = new BmwFactory(); 
        Car bmw = audiFactory.create(); 
        audi.run(); 
    } 
}

简单工厂模式和工厂方法模式的对比与选择:

工厂方法模式中,通过定义一个抽象的核心工厂类,并定义创建产品对象的接口,创建具体产品实例的工作需要到其工厂
子类去完成。这样做的好处是核心类只关注工厂类的接口定义,而具体的产品实例交给具体的工厂子类去创建。当
系统需要新增一个产品是,无需修改现有系统代码,只需要添加一个具体产品类和其对应的工厂子类,使系统的扩
展性变得很好,符合面向对象编程的开闭原则。

工厂方法模式虽然扩展性好,但是增加了编码难度,大量增加了类的数量,所以怎么选择还是看实际的需求。

1.3抽象工厂模式(暂不介绍)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值