深入理解Java的三种工厂模式

一、简单工厂模式

简单工厂的定义:提供一个创建对象实例的功能,而无须关心其具体实现。被创建实例的类型可以是接口、抽象类,也可以是具体的类

实现汽车接口

1 public interface Car {
2     String getName();
3 }

奔驰类

1 public class Benz implements Car {
2     @Override
3     public String getName() {
4         return "Benz";
5     }
6 }

宝马类

1 public class BMW implements Car {
2     @Override
3     public String getName() {
4         return "BMW";
5     }
6 }

简单工厂,既能生产宝马又能生产奔驰

 1 public class SimpleFactory {
 2     public Car getCar(String name){
 3         if (name.equals("BMW")){
 4             return new BMW();
 5         }else if (name.equals("benz")){
 6             return new Benz();
 7         }else {
 8             System.out.println("不好意思,这个品牌的汽车生产不了");
 9             return null;
10         }
11     }
12 }

测试类

1 public class SimpleFactoryTest {
2     public static void main(String[] args){
3         SimpleFactory simpleFactory = new SimpleFactory();
4         Car car = simpleFactory.getCar("BMW");
5         System.out.println(car.getName());
6     }
7 }

测试结果

1 BMW

根据简单工厂的定义,用户只要产品而不在乎产品如何生产,看起来好像很完美的样子。但大家想想,这个世界存在什么都生产的工厂吗?显然是不存在的,每一个汽车品牌都有自己的生产工厂,都有自己生产技术。映射到spring框架中,我们有很多很多种的bean需要生产,如果只依靠一个简单工厂来实现,那么我们得在工厂类中嵌套多少个if..else if啊?而且我们在代码中生产一辆汽车只是new一下就出来了,但实际操作中却不知道需要进行多少操作,加载、注册等操作都将体现在工厂类中,那么这个类就会变得紊乱,管理起来也很不方便,所以说每个品牌应该有自己的生产类。因为专一,所以专业嘛,这个时候工厂方法就出现了。

二、工厂方法

工厂接口

1 //定义一个工厂接口,功能就是生产汽车
2 public interface Factory {
3     Car getCar();
4 }

奔驰工厂

1 public class BenzFactory implements Factory {
2     @Override
3     public Car getCar() {
4         return new Benz();
5     }
6 }

宝马工厂

1 public class BMWFactory implements Factory{
2     @Override
3     public Car getCar() {
4         return new BMW();
5     }
6 }

测试类

1 public class FactoryTest {
2    public static void main(String[] args){
3        Factory bmwFactory = new BMWFactory();
4        System.out.println(bmwFactory.getCar().getName());
5        Factory benzFactory = new BenzFactory();
6        System.out.println(benzFactory.getCar().getName());
7    }
8 }

测试结果

1 BMW
2 Benz

根据上述代码可以看出,不同品牌的汽车是由不同的工厂生产的,貌似又是很完美的。但大家看一下测试类,当一个人想要去买一辆宝马汽车的时候(假设没有销售商),那么他就要去找宝马工厂给他生产一辆,过几天又想要买一辆奔驰汽车的时候,又得跑到奔驰工厂请人生产,这无疑就增加了用户的操作复杂性。所以有没有一种方便用户操作的方法呢?这个时候抽象工厂模式就出现了。

三、抽象工厂

抽象工厂

 1 public abstract class AbstractFactory {
 2
 3      protected abstract Car getCar();
 4
 5      //这段代码就是动态配置的功能
 6      //固定模式的委派
 7      public Car getCar(String name){
 8         if("BMW".equalsIgnoreCase(name)){
 9             return new BmwFactory().getCar();
10         }else if("Benz".equalsIgnoreCase(name)){
11             return new BenzFactory().getCar();
12         }else if("Audi".equalsIgnoreCase(name)){
13             return new AudiFactory().getCar();
14         }else{
15             System.out.println("这个产品产不出来");
16             return null;
17         }
18     }
19 }

默认工厂

1 public class DefaultFactory extends AbstractFactory {
2
3     private AudiFactory defaultFactory = new AudiFactory();
4
5     public Car getCar() {
6         return defaultFactory.getCar();
7     }
8
9 }

宝马工厂

1 public class BMWFactory extends AbstractFactory {
2     @Override
3     public Car getCar() {
4         return new BMW();
5     }
6 }

奔驰工厂

1 public class BenzFactory extends AbstractFactory {
2     @Override
3     public Car getCar() {
4         return new Benz();
5     }
6 }

测试类

1 public class AbstractFactoryTest {
2     public static void main(String[] args) {
3         DefaultFactory factory = new DefaultFactory();
4         System.out.println(factory.getCar("Benz").getName());
5     }
6 }

测试结果

1 Benz

根据上述代码可以看出,用户需要一辆汽车,只需要去找默认的工厂提出自己的需求(传入参数),便能得到自己想要产品,而不用根据产品去寻找不同的生产工厂,方便用户操作。注:对于设计模式,有些人嗤之以鼻,有些人敬若神明,但我是认可的。按我粗浅的理解,设计模式的经典之处,就在于解决了编写代码的人和调用代码的人双方的痛楚,不同的设计模式也只适用于不同的场景。至于用或者不用,如何使用,那就需要各位看官着重考虑了。但为了使用而使用是不应该的,细微之处,只有留给大家慢慢品味了。



来源:https://my.oschina.net/u/4052893/blog/2995128

原文地址:https://www.cnblogs.com/w13248223001/p/10389854.html

时间: 2024-10-07 03:27:23

深入理解Java的三种工厂模式的相关文章

Java的三种代理模式简述

本文着重讲述三种代理模式在java代码中如何写出,为保证文章的针对性,暂且不讨论底层实现原理,具体的原理将在下一篇博文中讲述. 代理模式是什么 代理模式是一种设计模式,简单说即是在不改变源码的情况下,实现对目标对象的功能扩展. 比如有个歌手对象叫Singer,这个对象有一个唱歌方法叫sing(). 1 public class Singer{ 2 public void sing(){ 3 System.out.println("唱一首歌"); 4 } 5 } 假如你希望,通过你的某种

设计模式:三种工厂模式

三种工厂模式 简单工厂实现 简单工厂模式(严格来说这不算一种Gof的设计模式,更像是一种编程习惯)属于类的创建型模式,又叫做静态工厂方法模式.通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有相同的父类,应用继承将决定工厂的生产什么产品的决定权直接交到了客户手中,然后客户在输入自己的需求,得到最终的结果. 运用简单工厂模式实现生产pizza的业务场景. /// <summary> /// pizza创建工厂 /// </summary> public class Pi

设计模式看书笔记(5) - 三种工厂模式比较

先看三种工厂模式部分主要代码(完整代码在前三篇博客): 简单工厂模式: public class SampleFactory { public static Animal createAnimal(String animalName){ if("Tiger".equals(animalName))){ return new Triger(); }else if("Dolphin".equals(animalName)){ return new Dolphin();

高级特性 三种工厂模式

简单工厂模式是属于创建型模式,又叫做静态工厂方法(Static Factory Method)模式,但不属于23种GOF设计模式之一.简单工厂模式是由一个工厂对象决定创建出哪一种产品类的实例.简单工厂模式是工厂模式家族中最简单实用的模式,可以理解为是不同工厂模式的一个特殊实现. 是通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类. 我们从一个实例展开 现在有一道面试题:使用java实现一个计算机控制台程序,要求输入数的运算,得到结果. 这道题目最原始的写法: publi

java三种工厂模式

适用场合: 7.3 工厂模式的适用场合 创建新对象最简单的办法是使用new关键字和具体类.只有在某些场合下,创建和维护对象工厂所带来的额外复杂性才是物有所值.本节概括了这些场合. 7.3.1 动态实现 如果需要像前面自行车的例子一样,创建一些用不同方式实现同一接口的对象,那么可以使用一个工厂方法或简单工厂对象来简化选择实现的过程.这种选择可以是明确进行的也可以是隐含的.前者如自行车那个例子,顾客可以选择需要的自行车型号:而下一节所讲的XHR工厂那个例子则属于后者,该例中所返回的连接对象的类型取决

java 三种工厂模式

一.简单工厂模式 一个栗子: 我喜欢吃面条,抽象一个面条基类,(接口也可以),这是产品的抽象类. public abstract class INoodles { /** * 描述每种面条啥样的 */ public abstract void desc(); } 先来一份兰州拉面(具体的产品类): public class LzNoodles extends INoodles { @Override public void desc() { System.out.println("兰州拉面 上海

Android 工厂模式,三种工厂模式的理解

工厂模式是一种创建者模式,在任何生成复杂对象的地方都可以使用工厂模式.理论来说在任何使用A a = new A()的方式都可以使用工厂模式,虽然使用工厂模式可能需要多做一些工作,但是在后续的开发和维护都带来了方便. 如果我们需要在构建对象的时候,需要做很多的处理工作,比如初始化工作,查询工作等一些耗时的工作,如果我们将这些操作全部放入到构造方法中去写,那么势必在后期维护的带来不方便,而且始化工作如果是很长一段代码,说明要做的工作很多,将很多工作装入一个方法中,相当于将很多鸡蛋放在一个篮子里,是很

设计模式—三种工厂模式(JAVA)

一:简单工厂: 有一个实际工厂,这个工厂只能造一类的产品,这一类产品就是一个产品接口,会有多个具体产品实现这个接口,例 如,一个手机厂,生产苹果手机,三星手机: 缺点:在工厂类中集中了所有实例的创建逻辑,违反了高内聚责任分配原则,将全部创建逻辑集中到了一个工厂类中:对系统的维护和扩展不利: 使用场景:负责创建的对象比较少:客户只知道传入工厂类的参数,对于如何创建对象的逻辑不关心:容易违反高内聚责任分配原则,所以只在很简单的情况下应用: package com.designPattern.simp

Java中的三种工厂模式

/** * 设计模式之工厂模式,用户创建对象的,通过工厂模式来降低代码的耦合度 * @author  */ //简单工厂模式 public class SimpleFactory{        /**     * 根据不过的String参数 name返回不同的汽车对象name     * @param name     * @return     */    public Car getCar(String name){                /*         * 利用equals