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工厂 --- 抽象工厂模式的更多相关文章

  1. JAVA设计模式--抽象工厂模式

    抽象工厂设计模式 1.系统中有多个产品族,而系统一次只可能消费其中一族产品2.同属于同一个产品族的产品以其使用.来看看抽象工厂模式的各个角色(和工厂方法的如出一辙):抽象工厂角色: 这是工厂方法模式的 ...

  2. Java设计模式-抽象工厂模式(Abstract Factory )

    工厂方法模式有一个问题就是,类的创建依赖工厂类,也就是说,如果想要拓展程序,必须对工厂类进行修改,这违背了闭包原则,所以,从设计角度考虑,有一定的问题,如何解决?就用到抽象工厂模式,创建多个工厂类,这 ...

  3. java 之 抽象工厂模式(大话设计模式)

    看了几次抽象工厂模式,每次查看都需要重新理解一次,可能是涉及的类和接口比较多,所以比较难缕清的关系吧!在笔者看来,我们还是要吸取其思想而不是生搬硬套. 来看下类图: 大话设计模式-类图 看类图已经很乱 ...

  4. 2.java设计模式-抽象工厂模式

    抽象工厂模式简介: 每一个模式都是针对某一种问题的解决方案.抽象工厂模式与工厂模式最大的区别在于,工厂模式针对的是一个产品等级结构,而抽象工厂模式面对的是多个产品等级结构,即产品族的概念. 这里讲解一 ...

  5. Java设计模式-抽象工厂模式(Abstarct Factory)

    抽象工厂模式 举个生活中常见的例子,组装电脑,在组装电脑时,通常需要选择一系列的配件,比如CPU,硬盘,内存,主板,电源,机箱等,为了讨论使用简单,值考虑选择CPU和主板的问题. 事实上,在选择CPU ...

  6. Java 实现抽象工厂模式

    抽象工厂模式 里面有几个概念:抽象工厂.实体工厂.抽象产品.实体产品 抽象工厂:定义创建产品的抽象方法 实体工厂:详细的创建哪种产品 抽象产品:一个接口或基类 实体产品:实现详细功能,或派生 类图 ...

  7. Java设计模式——抽象工厂模式

    抽象工厂模式也是创建模式,可以把它理解成创建工厂的工厂,这种模式也是我们经常使用的.在抽象工厂中的接口是用来创建工厂的,每个生成的工厂又都可以按照工厂模式创建其他对象. 举例说明: 创建Shape接口 ...

  8. java 简单工厂&抽象工厂

    工厂模式:就是提供一个实例化对象的接口,让子类去决定实现哪个具体对象 1:简单工厂 public abstract class Person { } public class XiaoLi exten ...

  9. java 使用抽象工厂封装特性方法

    1.创建抽象类:封装含有相同特性的方法. */ public abstract class AbstractPayment { public abstract String progress() th ...

随机推荐

  1. JSP常用内置对象

    1.request 1.1getAttribute(String name) 2.getAttributeName() 3.getCookies() 4.getCharacterEncoding() ...

  2. Docker通过阿里云镜像仓库使用Gitlab_CI部署SpringBoot项目

    Docker.Gitlab.阿里云镜像仓库.SpringBoot的相关安装.搭建这里就不讲了. Linux 安装 Docker :https://www.cnblogs.com/linnuo/p/15 ...

  3. JavaFx WebView使用研究

    原文: JavaFx WebView使用研究 | Stars-One的杂货小窝 本篇是基于TornadoFx框架的基础研究的,示例代码都是Kotlin版本,各位可以看着参考下 WebView中比较重要 ...

  4. Mac终端学习C笔记

    Mac终端自带Clang,是一个C语言.C++.Objective-C语言的轻量级编译器,也可以进行c程序编译.具体Clang和gcc区别不做详细介绍. 终端自动vi编辑器. 终端命令笔记: gcc ...

  5. vscode提示提示安装似乎损坏,请重新安装

    安装 Fix VSCode Checksums 插件 Ctrl+Shift+P , 输入Fix Checksums : Apply, 点击,重启即可

  6. LuoguP7714 「EZEC-10」排列排序 题解

    Content 给定一个 \(1\sim n\) 的一个排列 \(p\),你每次可以选择一个区间 \([l,r]\) 并花费 \(r-l+1\) 的代价将下标在这个区间内的所有数升序排序,求使得排列 ...

  7. CF734B Anton and Digits 题解

    Content 有 \(k_2\) 个 \(2\).\(k_3\) 个 \(3\).\(k_5\) 个 \(5\) 和 \(k_6\) 个 \(6\),你可以用这里面的数字来组成 \(256,32\) ...

  8. 如何把maven项目转为eclipse项目

    如何把maven项目转为eclipse项目,按照如下操作便可. 在cmd窗口, 载cmd窗口进入到maven项目所在目录下,输入如下命令: mvn eclipse:eclipse 这样便可.

  9. 【LeetCode】1405. 最长快乐字符串 Longest Happy String

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 贪心 日期 题目地址:https://leetcode ...

  10. 【LeetCode】205. Isomorphic Strings 解题报告(Java & Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 字典保存位置 字典保存映射 日期 题目地址:http ...