● 工厂方法模式介绍

工厂方法模式(Factory Pattern),是创建型设计模式之一。工厂方法模式是一种结构简单的模式,其在我们平时开发中应用很广泛,也许你并不知道,但是你已经使用了无数次该模式了,如Android中的Activity里的各个生命周期方法,以onCreate方法为例,它就可以看作是一个工厂方法,我们在其中可以构造我们的View,并通过setContentView返回给famework处理等,相关内容我们下面再讲,先来看看工厂方法的模式定义。

● 工厂方法模式的定义

定义一个用于创建对象的接口,让子类决定实例化哪个类。

● 工厂方法模式的使用场景

在任何需要生成复杂对象的地方,都可以使用工厂方法模式。复杂对象适合使用工厂模式,用new就可以完成创建的对象无需使用工厂模式。

● 工厂方法密码的UML类图

UML类图如下所示:

根据上图我们可以得出如下一个工厂方法模式的通用模式代码。

抽象产品类:

public abstract class Product {/*** 产品类的抽象方法* 由具体的产品类去实现*/public abstract void method();
}

具体产品类A

public class ConcreteProductA extends Product{@Overridepublic void method() {System.out.println("我是具体的产品A");}
}

具体的产品类B

public class ConcreteProductB extends Product{@Overridepublic void method() {System.out.println("我是具体的产品B");}
}

抽象工厂类

public abstract class Factory {/*** 抽象工厂方法* 具体生产什么有子类去实现* @return 具体的产品对象*/public abstract Product createProduct();
}

具体的工厂类

public class ConcreteFactory extends Factory{@Overridepublic Product createProduct() {return new ConcreteProductA();}
}

客户类

public class Client {public static void main(String[] args) {Factory factory = new ConcreteFactory();Product p = factory.createProduct();p.method();}
}

这里的几个角色都很简单,主要分为四大模块,一是抽象工厂,其为工厂方法模式的核心;二是具体工厂,其实现了具体的业务逻辑;三是抽象产品,是工厂方法模式所创建的产品父类;四是具体产品,为实现抽象产品的某个具体产品的对象。

上诉的代码中我们在Client类中构建了一个工厂对象,并通过其生产了一个产品对象,这里我们得到的产品对象是ConcreteProductA的实例,如果想得到ConereteProductB的实例,更改ConcreteFactory中的逻辑即可。

public class ConcreteFactory extends Factory{@Overridepublic Product createProduct() {return new ConcreteProductB();
//        return new ConcreteProductA();}
}

这种方法比较常见,需要哪一个产品就生产哪一个,有时候也可以利用反射的方式更简洁来生产具体产品对象,此时,需要在工厂方法的参数列表中传入一个Class类来决定是哪一个产品类。

public abstract class Factory {/*** 抽象工厂方法* 具体生产什么有子类去实现** @param clz 产品对象类类型* @return 具体的产品对象*/public abstract <T extends Product> T createProduct(Class<T> clz);
}

对于具体的工厂类,则通过反射获取累的实例即可。

public class ConcreteFactory extends Factory{@Overridepublic <T extends Product> T createProduct(Class<T> clz) {Product p = null;try {p = (Product) Class.forName(clz.getName()).newInstance();}catch (Exception e){e.printStackTrace();}return (T)p;}
}

最后再来看看Client中的实现。

public class Client {public static void main(String[] args) {Factory factory = new ConcreteFactory();Product p = factory.createProduct(ConcreteProductB.class);p.method();}
}

需要哪一个类的对象就传入哪一个类的类型即可,这种方法比较简洁、动态,如果你不喜欢这种方法,也可以尝试为每一个产品都定义一个具体的工厂,各司其职。

public class ConcreteFactoryA extends Factory {@Overridepublic Product createProduct() {return new ConcreteProductA();}
}
public class ConcreteFactoryB extends Factory {@Overridepublic Product createProduct() {return new ConcreteProductB();}
}
public class Client {public static void main(String[] args) {Factory factoryA = new ConcreteFactoryA();Product productA = factoryA.createProduct();productA.method();Factory factoryB = new ConcreteFactoryB();Product productB = factoryB.createProduct();productB.method();}
}

像这样拥有多个工厂的方式我们称为多工厂方法模式,同样的地,回到我们最初的那个工厂方法模式,当我们的工厂只有一个的时候,我么还是为工厂提供了一个抽象类,那么,我们是否可以将其简化掉呢?如果确定你的工厂类只有一个,那么简化掉抽象类是肯定没有问题的,我们只需要将对应的工厂方法改为静态方法即可。

public class ConcreteFactory extends Factory{@Overridepublic static Product createProduct() {return new ConcreteProductB();
//        return new ConcreteProductA();}
}

像这样方式有称为简单工厂模式或静态工厂模式,它是工厂模式的一个弱化版本。

其实到这里大家应该可以发现,工厂方法模式是完全符合设计原则的,其降低了对象之间的耦合度,而且,工厂方法模式依赖于抽象的框架,其将实例化的任务交由子类去完成,有非常好的扩展性。

● 工厂方法模式的简单实现

工厂方法模式对于大家来说是非常好理解的一个模式,即便是第一次听说,只要读者懂点Java知识,理解这个模式绝对不难,隐藏,对于模式的简单实现不再过得赘述,这里以一个生活中的小例子来说明。张三是一家汽车厂的厂长,对他来说,组装汽车没什么好神秘的,无非就是将一些进口的核心部件,比如发动机和一些国内的零部件组装起来,张三的汽车厂主要就是组装模块SUV车型,比如Q3、Q5、Q7对于这类车型来说,内部结构差异不是很大,因此,对张三来说,一条生产线足以应对这3种车型,对于该生产线张三提供了一个抽象类定义。

public abstract class AundiFactory {/*** 某车型的工厂方法** @param clz 具体的SUV类型型号类型* @param <T>* @return 具体型号的SUV车对象*/public abstract <T extends AudiCar> T createAudCar(Class<T> clz);}

那么有没有必要为每种车型都提供一条生产线呢?在这里,张三厂里所生产的3种SUV车型可能在主结构上并没有什么差异,因此,对于张三来说没有必要为每一种车型提供一条不同的生产线,一条生产线即可。

public class AudiCarFactory extends AundiFactory {@Overridepublic <T extends AudiCar> T createAudCar(Class<T> clz) {AudiCar car = null;try {car = (AudiCar) Class.forName(clz.getName()).newInstance();} catch (Exception e) {e.printStackTrace();}return (T) car;}
}

对于这3种车型,除了一些车都有的基本共性外,还提供了自动巡航功能,类似于无人驾驶,这些功能张三都使用一个抽象的基类来声明。

public abstract class AudiCar {/*** 汽车的抽象产品类* <p>* 定义汽车的一个行为方法 车可以启动开走*/public abstract void drive();/*** 汽车的抽象类* <p>* 定义汽车的一个行为方法 车可以自动巡航*/public abstract void selfNavigation();
}

接下来就是生产每一种具体的车型了。

public class AudiQ3 extends AudiCar {@Overridepublic void drive() {System.out.println("Q3启动啦!");}@Overridepublic void selfNavigation() {System.out.println("Q3开始自动巡航啦!");}
}
public class AudiQ5 extends AudiCar {@Overridepublic void drive() {System.out.println("Q5启动啦!");}@Overridepublic void selfNavigation() {System.out.println("Q5开始自动巡航啦!");}
}
public class AudiQ7 extends AudiCar {@Overridepublic void drive() {System.out.println("Q7启动啦!");}@Overridepublic void selfNavigation() {System.out.println("Q7开始自动巡航啦!");}
}

最后我们将各个类组装起来形成一条完整的流水线。

public class Client {public static void main(String[] args) {//构造一个制造汽车的工厂对象AudiFactory audiFactory = new AudiCarFactory();//生产Q3并启动AudiQ3 audiQ3 = audiFactory.createAudCar(AudiQ3.class);audiQ3.drive();audiQ3.selfNavigation();//生产Q5并启动AudiQ5 audiQ5 = audiFactory.createAudCar(AudiQ5.class);audiQ5.drive();audiQ5.selfNavigation();//生产Q7并启动AudiQ7 audiQ7 = audiFactory.createAudCar(AudiQ7.class);audiQ7.drive();audiQ7.selfNavigation();}
}

输入结果如下:

Q3启动啦!
Q3开始自动巡航啦!
Q5启动啦!
Q5开始自动巡航啦!
Q7启动啦!
Q7开始自动巡航啦!

从上诉大家可以看到,工厂方法模式的结构很简单,逻辑也基本类似,所以,上面例子于我们类图中所述的结构是很类似的。

工厂方法模式——应用最广泛的模式相关推荐

  1. 工厂方法(Factory Method)模式

    一.工厂方法(Factory Method)模式 工厂方法(FactoryMethod)模式是类的创建模式,其用意是定义一个创建产品对象的工厂接口,将实际创建工作推迟的子类中. 工厂方法模式是简单工厂 ...

  2. 设计模式的征途—3.工厂方法(Factory Method)模式

    上一篇的简单工厂模式虽然简单,但是存在一个很严重的问题:当系统中需要引入新产品时,由于静态工厂方法通过所传入参数的不同来创建不同的产品,这必定要修改工厂类的源代码,将违背开闭原则.如何实现新增新产品而 ...

  3. Factory Method(工厂方法)--对象创建型模式

    Factory Method(工厂方法)–对象创建型模式 一.意图 定义一个用于创建对象的接口,让子类决定实例化哪一个类.Factory Method使一个类的实例化延迟到其子类. 二.动机 1.在软 ...

  4. 创建对象_工厂方法(Factory Method)模式 与 静态工厂方法

    工厂方法模式: 定义:为创建对象定义一个接口,让子类决定实例化哪个类.工厂方法让一个类的实例化延迟至子类. 应用场景: 客户类不关心使用哪个具体类,只关心该接口所提供的功能: 创建过程比较复杂,例如需 ...

  5. 接口、工厂方法的设计模式、代理模式

    三.接口: 接口是定义的一种功能:interface关键字表明是一个接口,定义的是一个功能.这些功能也可以被类使用,表明的是此接口与这些类发生的关系. implements表明类实现接口,实现接口以后 ...

  6. 『设计模式』工厂方法模式

    23种设计模式+额外常用设计模式汇总 (持续更新) 工厂方法(Factory Method)模式 工厂方法模式是类的创建模式,其用意是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类中. 在工 ...

  7. 工厂模式(简单工厂、工厂方法、抽象工厂)

    简单工厂模式 从设计模式的类型上来说,简单工厂模式是属于创建型模式,又叫做静态工厂方法(StaticFactory Method)模式,但不属于23种GOF设计模式之一.简单工厂模式是由一个工厂对象决 ...

  8. 设计模式之六:工厂方法模式(Factory method Pattern)

    工厂方法(Factory Method)模式就是定义一个创建对象的工厂接口,将实际创建工作推迟到子类当中. 核心工厂类不再负责具体产品的创建,仅提供了具体工厂子类必须实现的接口,这样核心类成为一个抽象 ...

  9. 软件架构设计师-创建型模式-单例模式-原型模式-工厂方法模式-抽象工厂模式-建造者模式

    文章目录 1.单例模式 2.原型模式 3.工厂方法(Factory Method)模式 4.抽象工厂(AbstractFactory)模式 5.建造者(Builder)模式 6.作者答疑   在面向对 ...

最新文章

  1. 第三周项目三-输出星号图(1)
  2. Qt中内存泄露和半自动内存管理
  3. 2021暑假每日一题 【week1 完结】
  4. 初识单点登录及JWT实现
  5. 友善之臂编linux内核,友善之臂NanoPC-T3 Plus,s5p6818编译Linux内核流程
  6. 漫水填充及Photoshop中魔术棒选择工具的实现
  7. hdu4292Food(最大流Dinic算法)
  8. leetcode —— 1217. 玩筹码
  9. QT5新建工程错误-无法打开源文件QtWidgets/QApplication
  10. Android开发笔记(八十一)屏幕规格适配
  11. 策略为王编译错误2:error C1189: #error : MFC does not support
  12. java面笔试_java笔试手写算法面试题大全含答案
  13. 使用U盘制作win10启动盘
  14. 上传文件计算机传输的,电脑文件怎么传输到iPad
  15. python自动加减法_python实现随机加减法生成器
  16. Salient Object Detection Driven by Fixation Prediction 论文解读
  17. 华为中兴为何对未来信心十足?
  18. Qt设置按钮背景图片
  19. 华为OD机试 - 预订酒店(Java JS Python)
  20. 产品沉思录精选:为何知识资本将胜过金融资本

热门文章

  1. 宏病毒的研究与实例分析03——宏病毒处理篇
  2. 计算机一级考试操作题基础操作,计算机一级考试基础操作题.doc
  3. 【U3D引擎】没有切换中文选项切换中文模式?
  4. 2009年“五一”假期市民旅游指南
  5. python数据分析要求高性能计算机_仅需1秒!搞定100万行数据:超强Python数据分析利器...
  6. 中国十大调查研究咨询公司排名数据信息情况
  7. 利用poi将Html中table转为Excel
  8. 运营小技能:最有效的公众号运营技能详解(持续更新中)
  9. 使用EXCEl宏批量生成超链接
  10. C语言入门基础a++和++a的区别及运算符的优先级别