【设计模式】用通俗易懂的方式讲解工厂模式

简介: 在Java编程中,我们常常需要创建各种不同类型的对象来完成各种任务。然而,如果我们直接使用new操作符创建对象,就会导致代码出现严重的耦合性问题

在Java编程中,我们常常需要创建各种不同类型的对象来完成各种任务。然而,如果我们直接使用new操作符创建对象,就会导致代码出现严重的耦合性问题。例如,如果我们想要更换某个对象,就需要在所有创建该对象的地方都进行修改,这不符合软件设计中的开闭原则。为了解决这个问题,我们可以使用工厂模式来生产对象。这样,我们只需要与工厂进行交互,而不需要直接与对象进行交互,从而彻底解耦。如果需要更换对象,只需要在工厂中进行相应的更改即可,而不需要修改所有的创建对象的代码。

今天我们就用案例的方式来聊一聊工厂模式,工厂模式作为一种设计模式在许多项目里应用十分广泛,主要分为下面三种:

1.简单工厂模式

2.工厂方法模式

3.抽象工厂模式

举个例子说明一下

1.简单工厂模式

在不用工厂模式的情况下,例如我们之前可能直接用new关键字创建对象,假设在电商场景下,我们需要创建一个美团的商品和饿了么的商品,就像下面这样

Goods meiTuanGoods = new MeiTuanGoods("美团商品");
Goods elemeGoods = new ElemeGoods("饿了么商品");

这样写可能会出现前面我们提到的问题,"耦合性过高",如果我们有一天需要对创建美团商品的方式进行改动,那么需要在每个创建美团商品的地方进行改动,工程量变得非常巨大

解决方式

简单工厂模式类图
image.png

建立工厂类

public class SimpleFactory {
   
   

    public static Goods createGoods(String channel) {
   
   
        if (channel.equals("美团")) {
   
   
            return new MeiTuanGoods("美团商品");
        } else if (channel.equals("饿了么")) {
   
   
            return new ElemeGoods("饿了么商品");
        }
        return null;
    }
}

商品类


public class Goods {
   
   

    private String name;

    public Goods(String name) {
   
   
        this.name = name;
    }

    public String getName() {
   
   
        return name;
    }

    public void setName(String name) {
   
   
        this.name = name;
    }

    @Override
    public String toString() {
   
   
        return "Goods{" +
                "name='" + name + '\'' +
                '}';
    }
}

public class MeiTuanGoods extends Goods {
   
   
    public MeiTuanGoods(String name) {
   
   
        super(name);
    }
}

public class ElemeGoods extends Goods {
   
   
    public ElemeGoods(String name) {
   
   
        super(name);
    }
}

有了SimpleFactory工厂类,我们创建美团或是饿了么的商品时不再需要直接跟商品类打交道,而是通过工厂类创建出来,就像下面这样


public class Main {
   
   

    public static void main(String[] args) {
   
   
        Goods meiTuanGoods = SimpleFactory.createGoods("美团");
        System.out.println(meiTuanGoods);
        Goods elemeGoods = SimpleFactory.createGoods("饿了么");
        System.out.println(elemeGoods);
    }
}

这样一来,当发生改动时,只需要改变工厂类中创建商品的地方即可

优点:解耦,创建对象和业务逻辑分开

缺点:当我们需要加入新的商品创建方式时,例如加入淘宝商品,那么就需要在工厂类中再加一个if else判断来实现创建新商品的功能,这样就违反了开闭原则

2.工厂方法模式

工厂方法模式是对上一种模式的改进,我们对工厂的方法进行抽象化,让不同渠道的商品用不同的工厂类来创建,避免违反开闭原则

工厂方法模式类图
image.png

抽象的工厂类

public interface Factory {
   
   

    Goods createGoods();
}

具体实现工厂类


public class MeiTuanFactory implements Factory {
   
   
    @Override
    public Goods createGoods() {
   
   
        return new ElemeGoods("美团商品");
    }
}

public class ElemeFactory implements Factory {
   
   
    @Override
    public Goods createGoods() {
   
   
        return new ElemeGoods("饿了么商品");
    }
}

通过具体的工厂类创建商品

public class Main {
   
   

    public static void main(String[] args) {
   
   
        Factory factory = new MeiTuanFactory();
        Goods meiTuanGoods = factory.createGoods();
        System.out.println(meiTuanGoods);
    }
}

通过工厂方法模式的工厂类创建对象,如果新增一个商品渠道,我们只需要再建一个工厂实现类去实现Factory,用这个工厂实现类去创建新的商品就可以了

优点:满足了工厂模式除耦合的效果外还符合了开闭原则

缺点:新增一种商品时,需要建立对应的工厂实现类,增加了复杂性

3.抽象工厂模式

抽象工厂模式实际上是工厂方法模式的一种改进,上面的工厂方法模式只能满足我们创建同一种类的产品,根据不同业务的需要,我们将同一种类的业务放到同一个工厂类里,例如美团商品、美团商品种类等方法,统一放到一个工厂类,饿了么商品、种类放到另一个工厂类,就像下面这样

public interface Factory {
   
   
    Goods createGoods();
    Category createCategory();
}

public class MeiTuanFactory implements Factory {
   
   
    @Override
    public Goods createGoods() {
   
   
        return new ElemeGoods("美团商品");
    }

    @Override
    public Category createCategory() {
   
   
        return new Category();
    }
}

public class ElemeFactory implements Factory {
   
   
    @Override
    public Goods createGoods() {
   
   
        return new ElemeGoods("饿了么商品");
    }

    @Override
    public Category createCategory() {
   
   
        return new Category();
    }
}

设计模式在项目中是无处不在的,但是如何在合适的场景选择合适的设计模式却非常考验一个工程师的水平,项目中好的设计模式是非常优美的,我们只需要按照设计好的模式传参即可,试想一下,如果代码里存在大量硬编码的代码,每次改动都小心翼翼,稍有不慎则牵一发而动全身,那无论是对我们还是后来人都是极不友好的。

相关文章
|
设计模式 安全 Java
通俗易懂,值得收藏的 java 设计模式实战,装饰者模式 之 你不用改变,就让你的能力变强了
装饰模式指的是在不必改变原类文件和使用继承的情况下,动态地扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。
通俗易懂,值得收藏的 java 设计模式实战,装饰者模式 之 你不用改变,就让你的能力变强了
|
设计模式 存储 SQL
【设计模式】通俗易懂的Java设计模式篇!3
【设计模式】通俗易懂的Java设计模式篇!
|
设计模式 前端开发 Java
【设计模式】通俗易懂的Java设计模式篇!2
【设计模式】通俗易懂的Java设计模式篇!
|
设计模式 SQL NoSQL
【设计模式】通俗易懂的Java设计模式篇!1
【设计模式】通俗易懂的Java设计模式篇!
|
PHP uml
通俗易懂的设计模式
通俗易懂的设计模式 零、使用 1、安装 2、测试 一、什么是设计模式 二、设计模式的类型 三、设计模式的六大原则 四、UML类图 1、看懂UML类图 2、解释 五、资料 前言:花了一些时间再次熟悉了...
1783 0
|
2月前
|
设计模式 前端开发 搜索推荐
前端必须掌握的设计模式——模板模式
模板模式(Template Pattern)是一种行为型设计模式,父类定义固定流程和步骤顺序,子类通过继承并重写特定方法实现具体步骤。适用于具有固定结构或流程的场景,如组装汽车、包装礼物等。举例来说,公司年会节目征集时,蜘蛛侠定义了歌曲的四个步骤:前奏、主歌、副歌、结尾。金刚狼和绿巨人根据此模板设计各自的表演内容。通过抽象类定义通用逻辑,子类实现个性化行为,从而减少重复代码。模板模式还支持钩子方法,允许跳过某些步骤,增加灵活性。
105 11
|
3月前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
|
8天前
|
设计模式
「全网最细 + 实战源码案例」设计模式——模式扩展(配置工厂)
该设计通过配置文件和反射机制动态选择具体工厂,减少硬编码依赖,提升系统灵活性和扩展性。配置文件解耦、反射创建对象,新增产品族无需修改客户端代码。示例中,`CoffeeFactory`类加载配置文件并使用反射生成咖啡对象,客户端调用时只需指定名称即可获取对应产品实例。
66 40
|
9天前
|
设计模式 关系型数据库
「全网最细 + 实战源码案例」设计模式——简单工厂模式
简单工厂模式是一种创建型设计模式,通过工厂类根据传入参数创建不同类型的对象,也称“静态工厂方法”模式。其结构包括工厂类、产品接口和具体产品类。优点是封装性强、代码复用性好;缺点是扩展性差,增加新产品时需修改工厂类代码,违反开闭原则。适用于对象种类较少且调用者无需关心创建细节的场景。
45 19
|
5月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提升代码的可维护性与扩展性在软件开发过程中,设计模式是开发者们经常用到的工具之一。它们提供了经过验证的解决方案,可以帮助我们解决常见的软件设计问题。本文将介绍PHP中常用的设计模式,以及如何利用这些模式来提高代码的可维护性和扩展性。我们将从基础的设计模式入手,逐步深入到更复杂的应用场景。通过实际案例分析,读者可以更好地理解如何在PHP开发中应用这些设计模式,从而写出更加高效、灵活和易于维护的代码。
本文探讨了PHP中常用的设计模式及其在实际项目中的应用。内容涵盖设计模式的基本概念、分类和具体使用场景,重点介绍了单例模式、工厂模式和观察者模式等常见模式。通过具体的代码示例,展示了如何在PHP项目中有效利用设计模式来提升代码的可维护性和扩展性。文章还讨论了设计模式的选择原则和注意事项,帮助开发者在不同情境下做出最佳决策。