当前位置: 首页 > news >正文

设计模式 - 工厂模式

一、 简单工厂(Simple Factory Pattern)

1、概念

一个工厂对象决定创建出哪一种产品类的实力,但不属于GOF23种设计模式。
简单工厂适用于工厂类负责创建的对象较少的场景,且客户端只需要传入工厂类的参数,对于如何创建对象的逻辑不需要关心。

2、实例

1)简单定义

public interface ICourse {/*** 录制视频* @return*/public void record();
}
public class JavaCourse implements ICourse {public void record() {System.out.println("录制Java课程");}
}
public class PythonCourse implements ICourse {public void record() {System.out.println("录制Python课程");}
}
public class SimpleFactoryTest {public static void main(String[] args) {ICourse iCourse = new JavaCourse();iCourse .create("java");}
}

客户端也就是测试类中,依赖JavaCourse,如果业务拓展,需要增加更多的Course类型,那么客户端的依赖会变得臃肿。

2)优化1

基于上述,建议一个工厂类

public class CourseFactory {public ICourse create(String name){if("java".equals(name)){return new JavaCourse();}else if("python".equals(name)){return new PythonCourse();}else {return null;}}
}
public class SimpleFactoryTest {public static void main(String[] args) {//优化一CourseFactory courseFactory = new CourseFactory();courseFactory.create("java");}
}

客户端的调用简单了,但是如果业务继续拓展 ,工厂中的create()就要修改代码逻辑,不符合开闭原则。还可以继续优化。

3)优化二

利用反射

public class CourseFactory {public ICourse create(String className) {try {if (!(null == className || "".equals(className))) {return (ICourse) Class.forName(className).newInstance();}} catch (Exception e) {e.printStackTrace();}return null;}public ICourse create(Class<? extends ICourse> clazz){try {if (null != clazz) {return clazz.newInstance();}}catch (Exception e){e.printStackTrace();}return null;}
}
public class SimpleFactoryTest {public static void main(String[] args) {CourseFactory courseFactory = new CourseFactory();ICourse iCourse = courseFactory.create("com.SimpleFactoryPattern.SimpleTwo.JavaCourse");iCourse.record();CourseFactory courseFactory1 = new CourseFactory();ICourse iCourse1 = courseFactory1.create(JavaCourse.class);iCourse.record();}
}

产品的添加不再需要修改CourseFactory

3、案例

例如在Calendar类中

Calendar.getInstance()

在这里插入图片描述
在这里插入图片描述

缺点:
工厂类的职责相对过重,不易于扩展过于复杂的产品结构

二、工厂方法模式

1.概念

定义一个创建对象的接口,但让实现这个接口的类来决定实例化哪个类,工厂方法让类的实例化推迟到子类中。在工厂方法模式中用户只需要关心所需产品对应的工厂,无需关心创建细节。

2、实例

基于上面实例

public interface ICourseFactory {ICourse create();
}
public class JavaCourseFactory implements ICourseFactory {public ICourse create() {return new JavaCourse();}
}
public class PythonCourseFactory implements ICourseFactory {public ICourse create() {return new PythonCourse();}
}
public class FactoryMethodTest {public static void main(String[] args) {ICourseFactory factory = new PythonCourseFactory();ICourse course = factory.create();course.record();factory = new JavaCourseFactory();course = factory.create();course.record();}
}

适用场景:

  • 创建对象需要大量重复的代码
  • 客户端不依赖于产品类实例如何被创建、实现等细节
  • 一个类通过其子类来指定创建哪个对象

缺点:

  • 类的个数过多,增加复杂度
  • 增加系统的抽象性和理解难度

3、抽象工厂模式(Abastract Factory Pattern)

1、概念

提供一个创建一系列相关或者相互依赖对象的接口,无需指定具体的类。客户端不依赖于产品类实例如何被创建、实现等细节。强调的是一系列相关的产品对象(同一产品族)一起使用创建对象需要大量重复的代码,提供一个产品类的库,所有的产品以同样的接口出现,从而客户端不依赖于具体实现。

2、实例

public interface ICourse {/*** 录制视频* @return*/void record();
}
public interface INote {void edit();
}
public interface IVideo {void record();
}
public class JavaCourse implements ICourse {public void record() {System.out.println("录制Java课程");}
}
public class JavaNote implements INote {public void edit() {System.out.println("编写Java笔记");}
}
public class JavaVideo implements IVideo {public void record() {System.out.println("录制Java视频");}
}

同理可以创建其他课程,实现接口

public abstract class CourseFactory {public void init(){System.out.println("初始化基础数据");}protected abstract INote createNote();protected abstract IVideo createVideo();}
public class JavaCourseFactory extends CourseFactory {public INote createNote() {super.init();return new JavaNote();}public IVideo createVideo() {super.init();return new JavaVideo();}
}
public class AbstractFactoryTest {public static void main(String[] args) {JavaCourseFactory factory = new JavaCourseFactory();factory.createNote().edit();factory.createVideo().record();}
}

例如就是Java作为一个产品族,Python作为一个产品族等等。如果继续拓展产品等级,比如创建代码createCode(),就需要从抽象工厂到具体工厂都需要调整,不符合开闭原则。

缺点:

  • 规定了所有可能被创建的产品集合,产品族中扩展新的产品困难,需要修改抽象工厂的接口
  • 增加系统的抽象性和理解难度
http://www.lryc.cn/news/96564.html

相关文章:

  • elementUI this.$confirm 文字大小样式
  • Kafka的TimingWheel
  • 第2集丨webpack 江湖 —— 创建一个简单的webpack工程demo
  • Python(Web时代)——初识flask
  • 二、SQL-5.DQL-8).案例练习
  • 浙大数据结构第五周之05-树7 堆中的路径
  • C# Modbus TCP上位机测试
  • instr字符查找函数(oracle用instr来代替like)
  • trie树的一点理解
  • Linux CentOS监控系统的运行情况工具 - top/htop/glances/sar/nmon
  • Qt开发(2)——windows下调用外部程序
  • PostgreSQL查看数据库对象大小
  • 给el-table实现列显隐
  • 为Android构建现代应用——应用架构
  • 49:字符串的新增方法
  • Kaggle图表内容识别大赛TOP方案汇总
  • DAY2,Qt(继续完善登录框,信号与槽的使用 )
  • 【设计模式】设计原则-开闭原则
  • 【2500. 删除每行中的最大值】
  • Superset部署
  • Python3 学习笔记 ~ 怎样打印字符串
  • postgresql安装
  • ElasticSearch之IK分词器安装以及使用介绍
  • Linux系统安装部署Jenkins详细教程(图文讲解)
  • 基于ChatGPT聊天的零样本信息提取7.25
  • Pytorch个人学习记录总结 08
  • Ansible自动化运维学习——综合练习
  • Java中正则表达式
  • 13 硬链接和软链接
  • 智能合约安全审计