详谈 Java工厂 --- 抽象工厂模式
1.前言
感觉工厂模式都好鸡肋,还特别绕来绕去,当然,好处还是有的,将一些类似的业务都集成到工厂了,
不需要理会底层是怎么运行的,我只需要向调用工厂即可获取我要的结果,也不需要考虑工厂返回的东西类型,都是统一的,
操作方法也一样,但是代价是底层需要写一大堆东西,如果只是用一两次的业务,就不要构建工厂啦,我是懒得写。
什么是工厂模式?
就是为了尽可能将代码的耦合度降低而产生的设计模式。
2.总结
(1)感觉好鸡肋啊,写的还这么多,无语,就像个漏斗,当个分类器用。
(2)分两部分,工厂和 产品源 ,工厂负责打包分配的, 产品源 负责提供材料的.
(3)在产品源,
所有的材料本质上都是食物【Food接口】,往下分,可以分出苹果和面条两种【抽象类】,
抽象类实现接口,统让不同的抽象类统一了使用方法名称,同时使用java 多态 ,可以让不同的抽象类可以向上转到相同的食物类型。
再往下面分,会有各种苹果和面条【实现类】,
让实现类继承抽象类,统一了食物的使用方法名称,使用Java多态 ,可让实现类向上转类型,最终所有的食物都是归Food类型,
也就是说让不同的食物统一了类型,因此,消费者不再需要考虑这个食物需要用什么东西装,拿来能吃就行。
(4)在工厂,
工厂规定了可以吃的食物【工厂接口】,运给不同的销售地【工厂实现类】,
工厂实现类实现工厂接口,统一了对食物的操作方法,也能让不同的实现类向上转到相同的类型【工厂类型】。
我设立了摆地摊和大超市两个卖东西的地方,虽然地方不同,但是本质上都是卖食物的,根据不同的操作,
获取相应的食物【在方法里new食物对象】,不论是什么食物,本质都是食物,因此返回数据类型是Food【java多态,向最高类型转型】。
(5)消费者选择一个地点买东西,返回的都是食物工厂类型【java多态,向最高类型转型】,然后付钱【使用统一规定的操作方法获取食物】,
得到食物对象,类型都是食物,然后可以吃食物啦【对食物做统一规定的操作,由食物接口规定,如果不规定,食物多了,岂不会乱套?】
(6)因此,对消费者来说,只需要选择买东西的地方,选择要吃的食物类型,至于食物的产地,不需要在乎,能吃就行,而食物的选择是由
店主/地摊主【工厂实现类】决定,消费者给了钱,拿到了食物,就可以吃了,不需要考虑这个食物需要用什么东西装,
都统一用饭盒装【Food类型】,总不能拿个马桶盖来装吧?
(7)优点:当有新的食物,只需要添加相应的食物实现类,在可以卖该食物的工厂添加生成该食物的方法即可,如果添加了新工厂实现类,只需要实现工厂接口即可,不需改动原有的其他工厂代码。
(8)缺点:会产生很多文件,代码量也很大,绕来绕去的,容易弄错。
3.操作
(1)场景:消费者去买食物,可以去摆地摊 或 大超市够买,使用抽象工厂实现业务逻辑。
(2)目录结构

(3)食物接口

package com.example.javabaisc.factory.abstrctfactory.origin;
public interface Food {
public void getFood();
}
(4)抽象类

package com.example.javabaisc.factory.abstrctfactory.origin.abstractFood; import com.example.javabaisc.factory.abstrctfactory.origin.Food; /**
* 抽象类-面条类
*/
public abstract class AbstractNoodles implements Food {
/**
* 抽象方法
*/
public abstract void getFood();
}

package com.example.javabaisc.factory.abstrctfactory.origin.abstractFood; import com.example.javabaisc.factory.abstrctfactory.origin.Food; /**
* 抽象类--苹果类
*/
public abstract class AbstractApple implements Food {
/**
* 抽象方法
*/
public abstract void getFood();
}
(5)具体食物实现类

package com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.noodles;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.AbstractNoodles;
public class YLNoodles extends AbstractNoodles {
@Override
public void getFood() {
System.out.println("一乐拉面");
}
}

package com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.noodles;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.AbstractNoodles;
public class LZNoodele extends AbstractNoodles {
@Override
public void getFood() {
System.out.println("兰州拉面");
}
}

package com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.apple;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.AbstractApple;
public class YNApple extends AbstractApple {
@Override
public void getFood() {
System.out.println("云南苹果");
}
}

package com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.apple;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.AbstractApple;
public class SDApple extends AbstractApple {
@Override
public void getFood() {
System.out.println("山东苹果");
}
}
(6)工厂接口

package com.example.javabaisc.factory.abstrctfactory.factory; import com.example.javabaisc.factory.abstrctfactory.origin.Food; /**
* 工厂接口
*/
public interface FoodFactory {
//获取苹果类食物
public Food getApple();
//获取面条类食物
public Food getNoodles(); }
(7)工厂实现类
-----摆地摊

package com.example.javabaisc.factory.abstrctfactory.factory; import com.example.javabaisc.factory.abstrctfactory.origin.Food;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.apple.SDApple;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.apple.YNApple;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.noodles.LZNoodele;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.noodles.YLNoodles; /**
* 摆地摊-工厂
*/
public class BDTFactory implements FoodFactory{ @Override
public Food getApple() {
//云南苹果
return new YNApple();
} @Override
public Food getNoodles() {
//一乐拉面
return new YLNoodles();
}
}
-----到超市

package com.example.javabaisc.factory.abstrctfactory.factory; import com.example.javabaisc.factory.abstrctfactory.origin.Food;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.apple.SDApple;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.noodles.LZNoodele;
import com.example.javabaisc.factory.abstrctfactory.origin.abstractFood.noodles.YLNoodles; /**
* 大超市-工厂
*/
public class DCSFactory implements FoodFactory{ @Override
public Food getApple() {
//山东苹果
return new SDApple();
} @Override
public Food getNoodles() {
//兰州拉面
return new LZNoodele();
}
}
(8)测试类

package com.example.javabaisc.factory.abstrctfactory; import com.example.javabaisc.factory.abstrctfactory.factory.BDTFactory;
import com.example.javabaisc.factory.abstrctfactory.factory.DCSFactory;
import com.example.javabaisc.factory.abstrctfactory.factory.FoodFactory;
import com.example.javabaisc.factory.abstrctfactory.origin.Food;
import org.junit.jupiter.api.Test; public class AbsTest {
@Test
public void t() { System.out.println("去大超市买吃的");
//去大超市买吃的
FoodFactory dcs = new DCSFactory();
//吃苹果
Food food1 = dcs.getApple();
food1.getFood();
//吃面条
Food food2 = dcs.getNoodles();
food2.getFood();
System.out.println("=================");
//
System.out.println("去摆地摊买吃的");
//去摆地摊买吃的
FoodFactory bdt = new BDTFactory();
//吃苹果
Food food3 = bdt.getApple();
food3.getFood();
//吃面条
Food food4 = bdt.getNoodles();
food4.getFood();
}
}
(9)运行测试类,打印结果

详谈 Java工厂 --- 抽象工厂模式的更多相关文章
- JAVA设计模式--抽象工厂模式
抽象工厂设计模式 1.系统中有多个产品族,而系统一次只可能消费其中一族产品2.同属于同一个产品族的产品以其使用.来看看抽象工厂模式的各个角色(和工厂方法的如出一辙):抽象工厂角色: 这是工厂方法模式的 ...
- Java设计模式-抽象工厂模式(Abstract Factory )
工厂方法模式有一个问题就是,类的创建依赖工厂类,也就是说,如果想要拓展程序,必须对工厂类进行修改,这违背了闭包原则,所以,从设计角度考虑,有一定的问题,如何解决?就用到抽象工厂模式,创建多个工厂类,这 ...
- java 之 抽象工厂模式(大话设计模式)
看了几次抽象工厂模式,每次查看都需要重新理解一次,可能是涉及的类和接口比较多,所以比较难缕清的关系吧!在笔者看来,我们还是要吸取其思想而不是生搬硬套. 来看下类图: 大话设计模式-类图 看类图已经很乱 ...
- 2.java设计模式-抽象工厂模式
抽象工厂模式简介: 每一个模式都是针对某一种问题的解决方案.抽象工厂模式与工厂模式最大的区别在于,工厂模式针对的是一个产品等级结构,而抽象工厂模式面对的是多个产品等级结构,即产品族的概念. 这里讲解一 ...
- Java设计模式-抽象工厂模式(Abstarct Factory)
抽象工厂模式 举个生活中常见的例子,组装电脑,在组装电脑时,通常需要选择一系列的配件,比如CPU,硬盘,内存,主板,电源,机箱等,为了讨论使用简单,值考虑选择CPU和主板的问题. 事实上,在选择CPU ...
- Java 实现抽象工厂模式
抽象工厂模式 里面有几个概念:抽象工厂.实体工厂.抽象产品.实体产品 抽象工厂:定义创建产品的抽象方法 实体工厂:详细的创建哪种产品 抽象产品:一个接口或基类 实体产品:实现详细功能,或派生 类图 ...
- Java设计模式——抽象工厂模式
抽象工厂模式也是创建模式,可以把它理解成创建工厂的工厂,这种模式也是我们经常使用的.在抽象工厂中的接口是用来创建工厂的,每个生成的工厂又都可以按照工厂模式创建其他对象. 举例说明: 创建Shape接口 ...
- java 简单工厂&抽象工厂
工厂模式:就是提供一个实例化对象的接口,让子类去决定实现哪个具体对象 1:简单工厂 public abstract class Person { } public class XiaoLi exten ...
- java 使用抽象工厂封装特性方法
1.创建抽象类:封装含有相同特性的方法. */ public abstract class AbstractPayment { public abstract String progress() th ...
随机推荐
- XML解析器
1.非验证解析器 检查文档格式是否良好,如用浏览器打开XML文档时,浏览器会进行检查,即格式是否符合XML(可拓展标记语言)基本概念. 2.验证解析器 使用DTD(Document Type Defi ...
- solr8.2
https://www.cnblogs.com/carlosouyang/p/11352779.html
- Identity Server 4 从入门到落地(十一)—— Docker部署
前面的部分: Identity Server 4 从入门到落地(一)-- 从IdentityServer4.Admin开始 Identity Server 4 从入门到落地(二)-- 理解授权码模式 ...
- idea开发环境搭建ssh
idea2020完整web开发(struts2+spring+hibernate) idea破解 第一步: 下载最新的 IDEA 2020.3.2 版本安装包 https://www.jetbrain ...
- 热部署详细步骤---·> 小热身!
IDEA 2018.1.5 4版本 热部署 网址:https://www.jb51.net/softjc/629271.html
- JavaFile I/O流
Java 流(Stream).文件(File)和IO Java.io 包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io 包中的流支持很多种格式,比如:基本类 ...
- shell脚本 binlog方式增量备份mysql
一.简介 源码地址 日期:2018/4/12 介绍:复制Binlog日志方式的增量备份脚本,并保存固定天数的备份 效果图: 二.使用 适用:centos6+ 语言:中文 注意:使用前先修改脚本中变量 ...
- C++ 未初始化内存出现 flashback
在 C++ 中分配一个未初始化内存,然后读取它,会读取到这块内存之前被使用所留下的值,这种现象我称之为 flashback. 栈内存很容易出现这种现象,而且很容易观测出某种规律. for (int i ...
- 除了背八股文,Java面试更该这样准备
我可以这样说,哪怕你背了再多java八股文的答案,过面试也能靠运气,因为很多java面试的答案只限于技术理论说辞.但用我本文给出的方法去准备面试,能在不提升技术的前提下,大大提升你java面试的通过率 ...
- Oracle使用数据泵导入/导出数据(expdp/impdp)
Oracle使用数据泵导入/导出数据(expdp/impdp) A电脑上的操作(expdp数据导出) 运行cmd: 登录数据库,输入命令:sqlplus 使用管理员角色登录需要在用户名后加" ...