博客
关于我
设计模式:工厂模式
阅读量:247 次
发布时间:2019-03-01

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

工厂模式(Factory Pattern)是一种软件设计模式,通过将实例化交给工厂来完成,从而隐藏了对象的创建过程。这种模式的核心思想是:不直接使用new操作符创建对象,而是通过工厂来获取对象。工厂模式有两种实现方式,一种是普通工厂模式,另一种是抽象工厂模式。

在Java开发中,工厂模式常用于类的实例化管理。例如,假设我们需要创建不同语言的对象,如中文和英语。我们可以定义一个工厂接口,供具体工厂实现。具体工厂根据所需语言类型返回对应的对象。

工厂模式的实现步骤

  • 定义接口:定义一个接口,声明需要的操作。

  • 实现类:实现接口类,具体实现所需操作。

  • 工厂接口:定义一个工厂接口,声明如何创建对象。

  • 具体工厂:实现工厂接口,根据条件创建对象。

  • 使用工厂:通过工厂获取对象,调用对象的方法。

  • 代码示例

    package basic.datatype.pattern.factory;public interface Person {    void language();}
    package basic.datatype.pattern.factory;public class Chinese implements Person {    @Override    public void language() {        System.out.println("====Chinese====");    }}
    package basic.datatype.pattern.factory;public class English implements Person {    @Override    public void language() {        System.out.println("====English====");    }}
    package basic.datatype.pattern.factory;public class PersonFactory {    public Person getLanguage(String language) {        if (language == null) {            return null;        }        if (language.equalsIgnoreCase("Chinese")) {            return new Chinese();        } else if (language.equalsIgnoreCase("English")) {            return new English();        }        return null;    }}
    package basic.datatype.pattern.factory;public class FactoryPatternTest {    public static void main(String[] args) {        PersonFactory personFactory = new PersonFactory();        Person chineseLanguage = personFactory.getLanguage("chinese");        chineseLanguage.language();        Person englishLanguage = personFactory.getLanguage("english");        englishLanguage.language();    }}

    工厂模式的优点

  • 隐藏对象创建过程:用户无需直接操作new,简化了代码。

  • 灵活性:通过工厂切换对象类型,提升系统的灵活性。

  • 可扩展性:新增语言类型,只需添加对应的工厂和实现类即可。

  • 工厂模式通过抽象化对象的创建过程,降低了代码的耦合度,使系统更加灵活和可维护。

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

    你可能感兴趣的文章
    Oracle 如何处理CLOB字段
    查看>>
    oracle 学习
    查看>>
    oracle 定义双重循环例子
    查看>>
    ORACLE 客户端工具连接oracle 12504
    查看>>
    Oracle 客户端连接时报ORA-01019错误总结
    查看>>
    oracle 嵌套表 例子,Oracle之嵌套表(了解)
    查看>>
    Oracle 常用命令
    查看>>
    Oracle 常用的V$视图脚本(二)
    查看>>
    Oracle 并行原理与示例总结
    查看>>
    oracle 并集 时间_Oracle集合运算符 交集 并集 差集
    查看>>
    Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
    查看>>
    oracle 执行一条查询语句,把数据加载到页面或者前台发生的事情
    查看>>
    oracle 批量生成建同义词语句和付权语句
    查看>>
    oracle 抓包工具,shell 安装oracle和pfring(抓包) 及自动环境配置
    查看>>
    Oracle 拆分以逗号分隔的字符串为多行数据
    查看>>
    Oracle 排序中使用nulls first 或者nulls last 语法
    查看>>
    oracle 插入date日期类型的数据、插入从表中查出的数据,使用表中的默认数据
    查看>>
    Oracle 操作笔记
    查看>>
    oracle 数据库 安装 和优化
    查看>>
    oracle 数据库dg搭建规范1
    查看>>