博客
关于我
设计模式:工厂模式
阅读量: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 闪回关闭,关闭闪回即disable flashback的操作步骤
    查看>>
    oracle--用户,权限,角色的管理
    查看>>
    oracle00205报错,Oracle控制文件损坏报错场景
    查看>>
    Oracle10g EM乱码之快速解决
    查看>>
    Oracle10g下载地址--多平台下的32位和64位
    查看>>
    Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
    查看>>
    Oracle11G基本操作
    查看>>
    Oracle11g服务详细介绍及哪些服务是必须开启的?
    查看>>
    Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
    查看>>
    oracle12安装软件后安装数据库,然后需要自己配置监听
    查看>>
    Oracle——08PL/SQL简介,基本程序结构和语句
    查看>>
    Oracle——distinct的用法
    查看>>
    Oracle、MySQL、SQL Server架构大对比
    查看>>
    oracle下的OVER(PARTITION BY)函数介绍
    查看>>
    Oracle中DATE数据相减问题
    查看>>
    Oracle中merge into的使用
    查看>>
    oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
    查看>>
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    Oracle中Transate函数的使用
    查看>>
    oracle中关于日期问题的汇总!
    查看>>