Java设计模式-工厂方法模式和抽象工厂模式
工厂方法模式定义:
即定义一个创建对象的接口(即抽象工厂类),让其子类(具体工厂类)决定实例化哪一个类(具体产品类)。“一对一”的关系
1,一抽象工厂类派生出多个具体工厂类;
2,一抽象产品类派生出多个具体产品类;
3,每个具体工厂类只能创建一个具体产品类的实例。
UML图:
角色模块:
1,抽象工厂类:工厂方法模式的核心,定义一个创建对象的接口
2,具体工厂类:继承抽象工厂类,实现其工厂方法,实现具体业务逻辑
3,抽象产品类:是工厂方法模式所创建的产品的父类
4,具体产品类:实现抽象产品类的某个具体产品的对象。
工厂方法模式的代码模板:
Product.java
package com.hust.factory1;
//抽象产品类
public abstract class Product {//产品类的抽象方法,有具体的产品类去实现public abstract void method();
}
ConcreteProductA.java
package com.hust.factory1;
//具体产品类A
public class ConcreteProductA extends Product {public void method() {System.out.println("我是具体产品类A");}<span style="font-size:24px;">}
</span>
ConcreteProductB.java
package com.hust.factory1;
//具体产品类B
public class ConcreteProductB extends Product {public void method() {System.out.println("我是具体产品类B");}}
Factory.java
package com.hust.factory1;
//抽象工厂类
public abstract class Factory {//抽象的工厂方法,具体生产什么有子类去实现public abstract <T extends Product> T createProduct(Class<T> clz);
}
ConcreteFactory.java
/*** */
package com.hust.factory1;/*** @author tuke**/
public class ConcreteFactory extends Factory {/* * 需要哪一个类就传入哪一个类的类型*/public <T extends Product> T createProduct(Class<T> clz) {//传入一个class类要决定生产哪一个产品Product p=null;try {p=(Product) Class.forName(clz.getName()).newInstance();//根据类加载器实例化对象} catch (Exception e) { e.printStackTrace();}return (T) p;}}
Test.java
package com.hust.factory1;public class Test {/*** @param args*/public static void main(String[] args) {Factory mFactory=new ConcreteFactory();//实例化具体工厂Product mProductA=mFactory.createProduct(ConcreteProductA.class);//根据类名初始化具体产品mProductA.method();Product mProductB=mFactory.createProduct(ConcreteProductB.class);mProductB.method();}}
输出:
我是具体产品类A
我是具体产品类B
具体实现例子:由工厂方法生产奥迪Q3,奥迪Q5,奥迪Q7
AudiCar.java
package com.hust.factory2;
//抽象产品类
public abstract class AudiCar {//定义一个汽车的行为方法,车可以启动开走 public abstract void drive();//定义一个汽车的行为方法,车可以自动导航public abstract void selfNavigation();}
AudiCarQ3.java
/*** */
package com.hust.factory2;/*** @author Administrator**/
public class AudiQ3 extends AudiCar {@Overridepublic void drive() { System.out.println("Q3启动啦!");}@Overridepublic void selfNavigation() {System.out.println("Q3启自动导航啦!");}}
AudiCarQ5.java
package com.hust.factory2;public class AudiQ5 extends AudiCar {@Overridepublic void drive() {System.out.println("Q5启动啦!");}@Overridepublic void selfNavigation() {System.out.println("Q5开始巡航啦!");}}
AudiCarQ7.java
package com.hust.factory2;public class AudiQ7 extends AudiCar{@Overridepublic void drive() {System.out.println("Q7启动啦!");}@Overridepublic void selfNavigation() {System.out.println("Q7开始巡航啦!");}}
AudiCarFactory.java
package com.hust.factory2;
//具体工厂类
public class AudiCarFactory extends AudiFactory {//实现工厂方法,如果要实现扩展多功能,可以在抽象类里增加抽象方法,在具体类中实现,这样就可以生产多个产品@Overridepublic <T extends AudiCar> T createAudiCar(Class<T> clz) {AudiCar mAudiCar=null;try {mAudiCar=(AudiCar) Class.forName(clz.getName()).newInstance();} catch (Exception e) {e.printStackTrace();}return (T) mAudiCar;}}
AudiFactory.java
package com.hust.factory2;public abstract class AudiFactory {public abstract <T extends AudiCar> T createAudiCar(Class<T> clz);
}
AudiCarFactory.java
package com.hust.factory2;
//具体工厂类
public class AudiCarFactory extends AudiFactory {//实现工厂方法,如果要实现扩展多功能,可以在抽象类里增加抽象方法,在具体类中实现,这样就可以生产多个产品@Overridepublic <T extends AudiCar> T createAudiCar(Class<T> clz) {AudiCar mAudiCar=null;try {mAudiCar=(AudiCar) Class.forName(clz.getName()).newInstance();} catch (Exception e) {e.printStackTrace();}return (T) mAudiCar;}}
Test.java
package com.hust.factory2;public class TestAudiCar {/*** @param args*/public static void main(String[] args) {AudiFactory mAudiFactory=new AudiCarFactory();//构造一个工厂对象//工厂根据具体产品类的类类型生产产品,这里是上转型对象AudiCar Q3=mAudiFactory.createAudiCar(AudiQ3.class);AudiCar Q5=mAudiFactory.createAudiCar(AudiQ5.class);AudiCar Q7=mAudiFactory.createAudiCar(AudiQ7.class);Q3.drive();Q3.selfNavigation();Q5.drive();Q5.selfNavigation();Q7.drive();Q7.selfNavigation();}}
输出
Q3启动啦!
Q3启自动导航啦!
Q5启动啦!
Q5开始巡航啦!
Q7启动啦!
Q7开始巡航啦!
抽象工厂模式的定义:
为创建一组相关或相互依赖的对象提供一个接口,而且无需指定他们的具体类。
1,一个抽象工厂类,派生出多个具体工厂类;
2,多个抽象产品类,派生出多个具体产品类;
3,每个具体工厂类可创建多个具体产品类的实例。
UML图:
抽象工厂代码模板:
package com.hust.model;//抽象工厂类
public abstract class AbstractFactory {//A和B是一组或相互依赖的对象public abstract AbstractProductA createProductA();//生产产品A的抽象方法public abstract AbstractProductB createProductB();//生产产品B的抽象方法
}
package com.hust.model;
//具体工厂1 生产具体类A1,B1
public class ConcreteFactory1 extends AbstractFactory {public AbstractProductA createProductA() {return new ConcreteProductA1();}public AbstractProductB createProductB() {return new ConcreteProductB1();}}
package com.hust.model;
//具体工厂2 生产具体类A2,B2
public class ConcreteFactory2 extends AbstractFactory {public AbstractProductA createProductA() {return new ConcreteProductA2();}public AbstractProductB createProductB() {return new ConcreteProductB2();}}
/*** */
package com.hust.model;/*** @author tuke**/
//抽象产品类A
public abstract class AbstractProductA {public abstract void method();
}
package com.hust.model;
//具体产品类A1
public class ConcreteProductA1 extends AbstractProductA {public void method() {System.out.println("具体产品A1的方法");}}
package com.hust.model;
//具体产品类A2
public class ConcreteProductA2 extends AbstractProductA {public void method() {System.out.println("具体产品A2的方法");}}
package com.hust.model;//抽象产品类B
public abstract class AbstractProductB {public abstract void method();
}
package com.hust.model;
//具体产品类B1
public class ConcreteProductB1 extends AbstractProductB {public void method() {System.out.println("具体产品B1的方法");}}
package com.hust.model;
//具体产品类B2
public class ConcreteProductB2 extends AbstractProductB {public void method() {System.out.println("具体产品B2的方法");}}
抽象工厂模式的简单实现:
还拿工厂生产奥迪Q3和Q7,是一个车系,但是零部件差别很大,Q3的发动机是国产的,Q7的发动机是原装进口的,Q3的轮胎是普通轮胎,Q7的轮胎是全尺寸越野轮胎,Q3使用的是比较普通的制动系统,而Q7是使用制动性能极好的制动系统。
虽然是一个车系,但是发动机,轮胎,制动系统对应的是一系列零部件。
汽车工厂需要生产轮胎,发动机,制动系统这3个零部件
抽象车厂类
package com.hust.audi;
//一个抽象工厂,只声明生产哪一类产品,具体的产品有子工厂去实现
public abstract class CarFactory {public abstract ITire createITire();//生产轮胎public abstract IEngine createIEngine();//生产发动机public abstract IBrake createIBrake();//生产制动系统
}
具体Q3子工厂
package com.hust.audi;public class Q3Factory extends CarFactory {public ITire createITire() { return new NormalTire();}public IEngine createIEngine() { return new DomesticEngine();}public IBrake createIBrake() { return new NormalBrake();}}
具体Q7子工厂
package com.hust.audi;public class Q7Factory extends CarFactory {public ITire createITire() { return new SUVTire();}public IEngine createIEngine() { return new ImportEngine();}public IBrake createIBrake() { return new SeniorBrake();}}
轮胎相关类
/*** */
package com.hust.audi;/*** 轮胎**/
public interface ITire {void tire();
}
package com.hust.audi;public class NormalTire implements ITire {public void tire() {System.out.println("普通轮胎");}
}
package com.hust.audi;public class SUVTire implements ITire {public void tire() {System.out.println("越野轮胎");}}
发动机相关类
/*** */
package com.hust.audi;/*** 发动机**/
public interface IEngine {void engine();
}
package com.hust.audi;public class DomesticEngine implements IEngine {public void engine() {System.out.println("国产发动机");}}
package com.hust.audi;public class ImportEngine implements IEngine {public void engine() {System.out.println("进口发动机");}}
制动系统相关类
/*** */
package com.hust.audi;/*** 制动系统**/
public interface IBrake {void brake();
}
package com.hust.audi;public class NormalBrake implements IBrake {public void brake() {System.out.println("普通制动");}}
package com.hust.audi;public class SeniorBrake implements IBrake {public void brake() {System.out.println("高级制动");}}
Test.java
package com.hust.audi;public class Test {/**
* Q3工厂生产:
普通轮胎
国产发动机
普通制动
-------------------
Q7工厂生产:
越野轮胎
进口发动机
高级制动
*/public static void main(String[] args) {//构造一个Q3工厂CarFactory mQ3Factory=new Q3Factory();System.out.println("Q3工厂生产:");mQ3Factory.createITire().tire();mQ3Factory.createIEngine().engine();mQ3Factory.createIBrake().brake();System.out.println("-------------------");//构造一个Q7工厂CarFactory mQ7Factory=new Q7Factory();System.out.println("Q7工厂生产:");mQ7Factory.createITire().tire();mQ7Factory.createIEngine().engine();mQ7Factory.createIBrake().brake();}}
抽象工厂模式与工厂方法模式的区别:
抽象工厂模式是工厂方法模式的升级版本,他用来创建一组相关或者相互依赖的对象。
他与工厂方法模式的区别就在于,工厂方法模式针对的是一个产品等级结构;而抽象工厂模式则是针对的多个产品等级结构。
在编程中,通常一个产品结构,表现为一个接口或者抽象类,也就是说,工厂方法模式提供的所有产品都是衍生自同一个接口或抽象类,而抽象工厂模式所提供的产品则是衍生自不同的接口或抽象类。
在抽象工厂模式中,有一个产品族的概念:所谓的产品族,是指位于不同产品等级结构中功能相关联的产品组成的家族。抽象工厂模式所提供的一系列产品就组成一个产品族;而工厂方法提供的一系列产品称为一个等级结构
Java设计模式-工厂方法模式和抽象工厂模式相关推荐
- 抽象工厂和工厂方法示例_抽象工厂设计模式示例
抽象工厂和工厂方法示例 本文是我们名为" Java设计模式 "的学院课程的一部分. 在本课程中,您将深入研究大量的设计模式,并了解如何在Java中实现和利用它们. 您将了解模式如此 ...
- 『创建型』简单工厂SimpleFactory、工厂方法FactoryMethod、抽象工厂AbstractFactory
为什么80%的码农都做不了架构师?>>> 几点说明 永远不要纠结于在什么时候使用什么模式 永远不要纠结于什么模式适用于什么情景 永远不要去死记任何的模式 并不是说,23种设计模 ...
- Java设计模式笔记(3)抽象工厂模式
抽象工厂模式:为创建一组相关的或者相互依赖的对象提供一个接口,而且无需指定他们的具体类. 抽象工厂模式是工厂方法模式的升级版本,在有多个业务品种.业务分类时,通过抽象工厂模式产生需要的对象是一种非常好 ...
- 对设计模式的总结之工厂方法模式和抽象工厂模式
前言 面向对象编程追求的本质-提高扩展性.可维护性.灵活性和复用性.合理利用面向对象6个原则,能够很好的达到要求.如何利用好就是至关重要的了,前人总结了23+个设计模式能够让初学者更容易学到其中的精髓 ...
- 【每天一个java设计模式(二十三)】 - 访问者模式
在访问者模式中,我们使用了一个访问者类,它改变了元素类的执行算法.通过这种方式,元素的执行算法可以随着访问者改变而改变.这种类型的设计模式属于行为型模式.根据模式,元素对象已接受访问者对象,这样访问者 ...
- 【每天一个java设计模式(十五)】 - 命令模式
命令模式是一种数据驱动的设计模式,它属于行为型模式.请求以命令的形式包裹在对象中,并传给调用对象.调用对象寻找可以处理该命令的合适的对象,并把该命令传给相应的对象,该对象执行命令. 命令模式也就是一个 ...
- 【每天一个java设计模式(十四)】 - 解释器模式
解释器模式提供了评估语言的语法或表达式的方式,它属于行为型模式.这种模式实现了一个表达式接口,该接口解释一个特定的上下文. 解释器模式主要包括以下几个部分: 抽象表达式角色:定义解释器的接口,约定解释 ...
- Java设计模式之工厂方法模式与抽象工厂模式
2019独角兽企业重金招聘Python工程师标准>>> 一.前期回顾 上一篇<Java设计模式之单例模式>详细介绍了单例模式,介绍了单例模式的使用场景,优缺点,同时也写了 ...
- JAVA设计模式——工厂模式【简单工厂模式、工厂方法模式、抽象工厂模式】
目录 简单工厂模式 传统方式 简单工厂模式 静态工厂模式 工厂方法模式 抽象工厂模式 工厂模式JDK-Calendar源码分析 工厂模式小结 简单工厂模式 看一个具体的需求 看一个披萨的项目:要便 ...
最新文章
- 为360极速浏览器添加搜索引擎
- 如何使用CNN进行物体识别和分类_CNN原理与实践指南
- 认清企业现状,做好信息化建设
- PS基础教程[3]如何去除照片上的水印
- Docker学习总结(26)——Docker 管理工具的选择:Kubernetes 还是 Swarm?
- 【证明】【一题多解】—— 负梯度方向的证明
- 计算机图形学跳一跳_微信小游戏“跳一跳”对内部审计师的启示
- 【存储测试】vdbench存储性能测试工具
- 数学建模笔记(一):数学建模一般步骤
- 【转载】Aquanaut:水下变形金刚
- LVM的常用操作【创建lvm】
- 55、【图】Dijkstra求最短路径(单源最短路径+边权重为正数)(C/C++版)
- Android menu属性详解
- “终于我从字节离职了...“一个年薪40W的测试工程师的自白..
- pku,zju题目分类
- 数据结构(舞伴问题)
- scrapy爬取豆瓣电影中演员合作关系制作gephi图
- 百度SEO站群黑侠超级站群助手
- 和我一起学 Three.js【初级篇】:3. 掌握摄影机
- 迈高图手机版_迈高图|地区工具电脑版下载_最火软件站
热门文章
- STM32 串口 #pragma import(__use_no_semihosting)解析
- stm32 IAP APP 相互跳转实验 (keil4 jlink STM32F407ZE
- jacoco入门_代码覆盖度工具jacoco的入门
- 深度探索C++ 对象模型(3)-默认构造函数Default Constructor续
- 134. 加油站(贪心算法)
- 1-Alternative Boot Flows
- Celery基本介绍
- 160个Crackme018
- 160个Crackme014
- 【NGINX+PHP7.3+MYSQL】安装指南