博客
关于我
设计模式深入浅出--4.抽象工厂coding以及JDK中的使用
阅读量:743 次
发布时间:2019-03-17

本文共 1413 字,大约阅读时间需要 4 分钟。

抽象工厂模式在课程系统中的应用

1. 定义 & 功能

抽象工厂模式提供了一种创建一系列相关或相互依赖对象的接口,无需关心具体的实现类。

2. 适用场景

当系统需要创建一系列相关的对象(如课程系统中的视频和笔记),且这些对象之间存在密切关系或依赖时,抽象工厂模式非常有用。

3. 应用场景:课程系统

在课程系统中,不仅需要创建视频,还需要创建对应的手记(笔记)。这要求系统能够同时创建多个相关对象,且如何创建这些对象的具体实现不影响系统的整体功能。

4. 类结构设计

4.1 产品接口

定义通用的产品接口,如Video和Article,确保所有产品都具有共同的方法 signatures。

4.2 抽象工厂接口

定义一个抽象工厂接口,提供创建产品的方法。例如:

public interface CourseFactory extends Factory {    Course createCourse();    Video createVideo();    Article createNote();}

4.3 具体工厂实现

实现抽象工厂接口,针对特定课程类型创建对应的产品。例如,JavaCourseFactory:

public class JavaCourseFactory implements CourseFactory {    public Course createCourse() {        return new JavaCourse();    }    public Video createVideo() {        return new JavaVideo();    }    public Article createNote() {        return new JavaArticle();    }}

4.4 产品具体实现

实现通用接口,具体实现各产品的功能。例如,JavaVideo和JavaArticle:

public class JavaVideo implements Video {    // 实现 video 相关方法}public class JavaArticle implements Article {    // 实现 note 相关方法}

5. 测试类设计

设计一个Test类来调用工厂创建课程。例如:

public class Test {    public static void main(String[] args) {        CourseFactory factory = new JavaCourseFactory();        Course course = factory.createCourse();        System.out.println("课程已创建:" + course.getName());    }}

6. 优点

  • 解耦:客户端不依赖具体实现,简化了维护工作。
  • 扩展性:方便添加新的课程类型,只需创建新的工厂和产品实现。
  • 7. 缺点

  • 耦合性:如果需要纵向扩展(增加产品等级结构),需修改工厂接口。
  • 封闭性:如果需要横向扩展(新增工厂),需新增工厂实现。
  • 8. 适用性

    在课程系统中,抽象工厂模式非常适合,因为它允许系统方便地创建多种课程类型的组合,而无需关心每个课程的具体实现。

    转载地址:http://gybhz.baihongyu.com/

    你可能感兴趣的文章
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
    查看>>