工厂设计模式灵魂拷问-Java实现

show me the code and take to me,做的出来更要说的明白
GitHub项目JavaHouse同步收录
喜欢就点个赞呗! 你的支持是我分享的动力!

引入

我们经常听到工厂模式,比如说 Spring 用了工厂模式啦,面试也会被问到工厂模式等等,这见工厂模式是日常开发中比较重要的一种设计模式。其实工厂模式也是比较简单的一种设计模式,这年头似乎不了解工厂模式,你都不好意思说你学过 编程一样(手动狗头)。那么,允许我灵魂拷问一下,你真的了解工厂模式吗。

UML类图

不急,我们先看看 UML 类图。学习一下怎么用 UML 类图 表示代码。先看如何表示一个实体类。代码如下:

public class B {

    private String name;
    private String password;

    public void test(){

    }
}

这是一个简单的实体类。他的 看 UML 类图如下:

看完实体类,我们在来看看接口,代码如下:

public interface B {
    void test();
}

这是一个简单的接类。一般接口就放几个方法,不放属性。他的 看 UML 类图如下:

看完实体类和接口,我们来看看他们有什么关系吧。先看看继承关系如何表示:

可以一眼看到他的箭头特点---空心的。箭头指向父类。这就是继承关系表示。

看完继承关系,我们在看看实现接口如何表示。

这里我们可以看到与继承关系类似,不过实现变成虚线,箭头指向接口类。

完了没有,没有,我们在看看依赖关系,这种关系比较弱,一般是一个类作为另一个类的参数表示, uml 图如下:

依赖关系是虚线,半个箭头

到这里,以上就是常见的 uml 类图表示。

简单工厂

进入正题,什么是工厂模式,我们先看看简单工厂模式,其实简单工厂模式并不是工厂模式,但是他可以帮助我们去了解工厂模式,所以我们先看看简单工厂模式。

需求:我们需要做一个可以加减乘除的计算机,运用到简单工厂模式。

UML 类图:

运算类:

import lombok.Data;

@Data
public abstract class Operation {
    private Double numA;
    private Double numB;
    /**
     * 运算方法
     */
    abstract Double getResult();
}

加法类:

public class OperationAdd extends Operation{

    @Override
    Double getResult() {
        return getNumA() + getNumB();
    }
}

乘法类:

public class OperationMul extends Operation{
    @Override
    Double getResult() {
        return getNumA() * getNumB();
    }
}

除法类:

public class OperationDiv extends Operation{
    @Override
    Double getResult() {
        if (getNumB() == 0){
            throw new RuntimeException("除数不能为零!");
        }
        return getNumA() / getNumB();
    }
}

简单工厂类:

public class CreateOperationFactory {
    public static Operation createOperation(String operate){
        Operation operation = null;
        switch (operate){
            case "+":
                operation = new OperationAdd();
                System.out.println("这是+法");
                break;
            case "/":
                operation = new OperationDiv();
                System.out.println("这是/法");
                break;
            case "*":
                operation = new OperationMul();
                System.out.println("这是*法");
                break;
        }
        return operation;
    }
}

测试类:

public class Test {
    public static void main(String[] args) {
        Operation operation = CreateOperationFactory.createOperation("+");
        operation.setNumA(1D);
        operation.setNumB(2D);
        System.out.println(operation.getResult());

        operation = CreateOperationFactory.createOperation("*");
        operation.setNumA(1D);
        operation.setNumB(2D);
        System.out.println(operation.getResult());

        operation = CreateOperationFactory.createOperation("/");
        operation.setNumA(1D);
        operation.setNumB(2D);
        System.out.println(operation.getResult());
    }
}

输出接口:

这是+法
3.0
这是*法
2.0
这是/法
0.5

工厂模式

需求:要再添加一个减法运算,嗯?上面没有减法运算吗?我猜你们肯定没有发现上面没有减法运算。看到的也会以为我在偷懒了,蒙混过关呢。事情并没有这么简单。

一般来说,加个减法嘛,简单,我直接就下 工厂类里面加一个分支不就完事了。哈哈,殊不知,这时候,我们已经违反一个重要的原则--开放关闭原则。所谓开放关闭原则,我们不应该修源码,祖传代码你敢动,试试看,而是通过继承父类或者实现接口去拓展代码,达到我们的目的。

uml 类图:

代码如下:

public interface IFactory {
    Operation createOperation(String operate);
}

public class OperationAddFactory implements IFactory{
    @Override
    public Operation createOperation(String operate) {
        Operation operation = new OperationAdd();
        System.out.println("这是+法");
        return operation;
    }
}

抬杠

没错,这里是自己杠自己的环节。

什么工厂模式啊!我自己 new 一个对应的对象不就解决问题了,为啥要写一个工厂类出来。(杠上杠啊,这是要搞事情)

嗯?好像我无法反驳·····是不存在的(用我第三根手指推一推我的眼镜)。试想一下,一个地方用到就去 new 一下。我们一下new了十几个地方,然后发现要来类名,这时候,怎么办。一处一处改咯,自己new的对象,哭着也要改完。但是如果用工厂类的话,我们只需要改一个地方就可以,就是这么简单。

就这一个优点吗?我还是喜欢一个一个new啊。

肯定不是(这是一个杠精啊),当然简单一个new对象,确实不需要写一个类出来。但是new一个对象并不是那么简单,我们需要对象进行一个操作呢。Spring IOC机制默认创建对象是单例的,那么我们现在也需要对象是唯一的怎么办。这时候,我们就是可以在工厂类里面写一个单例模式,达到我们的目的。

以上就是我的抬杠环节。

总结

不管什么设计模式,其实就是为了代码复用,少写代码,我们做明白什么模式是什么模式,更要理解这些的作用。正所谓,武术的目的是为了生发,战争的出发点是为了和平。总之,就是知其然知其所以然。

看到这里的都是人才。

参考

https://juejin.im/post/5d318b485188255957377ac3#heading-4
《大话设计模式》
https://www.zhihu.com/question/24843188 -- 工厂设计模式有什么用?

关注微信公众号,随时移动端阅读

原文地址:https://www.cnblogs.com/chenzhuantou/p/12117851.html

时间: 2024-10-08 22:10:50

工厂设计模式灵魂拷问-Java实现的相关文章

Java 工厂设计模式

//使用new关键字创建对象的缺点是耦合度太高,工厂设计模式利用Java的反射机制来实例化对象降低了这种耦合度 package cn.buaa; import java.util.Date; interface Fruit{  public void eat(); } class Apple implements Fruit{  @Override  public void eat() {   System.out.println("吃苹果");     } } class Orang

【51】java设计模式-工厂设计模式剖析

工厂设计设计模式的分类: 工厂模式在<Java与模式>中分为三类: 1)简单工厂模式(Simple Factory):不利于产生系列产品: 2)工厂方法模式(Factory Method):又称为多形性工厂: 3)抽象工厂模式(Abstract Factory):又称为工具箱,产生产品族,但不利于产生新的产品: 这三种模式从上到下逐步抽象,并且更具一般性. GOF在<设计模式>一书中将工厂模式分为两类:工厂方法模式(Factory Method)与抽象工厂模式(Abstract F

灵魂拷问:如何检查Java数组中是否包含某个值 ?

摘自:https://www.cnblogs.com/qing-gee/p/12053156.html 在逛 programcreek 的时候,我发现了一些专注细节但价值连城的主题.比如说:如何检查Java数组中是否包含某个值 ?像这类灵魂拷问的主题,非常值得深入地研究一下. 另外,我想要告诉大家的是,作为程序员,我们千万不要轻视这些基础的知识点.因为基础的知识点是各种上层技术共同的基础,只有彻底地掌握了这些基础知识点,才能更好地理解程序的运行原理,做出更优化的产品. 我曾在某个技术论坛上分享过

灵魂拷问:Java如何获取数组和字符串的长度?length还是length()?

限时 1 秒钟给出答案,来来来,听我口令:"Java 如何获取数组和字符串的长度?length 还是 length()?" 在逛 programcreek 的时候,我发现了上面这个主题.说实话,我当时脑海中浮现出了这样一副惊心动魄的画面: 面试官老马坐在我的对面,地中海式的发型令我敬佩有加.尽管略显疲惫,但他仍然自信地向我抛出了上面这个问题.稍稍迟疑了一下,我回答说:"数组用 length,字符串用 length 跟上小括号".老马不愧是面试中的高手,一瞬间就从我的

java设计模式之工厂设计模式(Factory)

设计模式根据使用类型可以分为三种:1. 创建模式: Factory (工厂模式). Singleton (单态). Builder ( (建造者模式). Prototype ( (原型模式).工厂方法模式. 2. 结构模式: Flyweight ( (共享模式). Bridge ( (桥模式). Decorator ( (装饰模式). Composite ( (组合模式). Adapter (适配器模式). Proxy ( (代理模式). Facade ( (外观模式). 3. 行为模式: It

java设计模式----工厂设计模式

目录   1.面向对象设计的基本原则 2.简单工厂模式 3.工厂方法模式 4.抽象工厂模式   工厂设计模式的核心本质: 1.实例化对象,用工厂方法代替new操作. 2.将选择实现类.创建对象统一管理和控制.从而将调用者跟我们的实现类解耦. 一.面向对象设计的基本原则 1.OCP(开闭原则,Open-Closed Principle):一个软件的实体应当对扩展开放,对修改关闭. 2.DIP(依赖倒转原则,Dependence Inversion Principle):要针对接口编程不要针对实现编

简单工厂设计模式

说起设计模式,不得不从最简单的简单工厂设计模式开始说起. 简单工厂模式:定义一个工厂类,它可以根据参数的不同返回不同类的实例,被创建的实例通常具有共同的父类.因为简单工厂模式中用于创建的方法是静态的,因此简单工厂模式又被称为静态工厂方法(Static Factory Method)模式,属于类创建型模式. 首先我们先看看下面这个类图: 在这个类图中,我们可以发现,静态工厂一共有三个对象是不可缺少的 1公共父类(Fruit接口) 2具体的产品类(Apple, Banana) 3静态工厂类(Simp

抽象工厂设计模式

/** 抽象工厂设计模式:与工厂设计模式是一样的,只不过抽象工厂是多产品系的. 工厂模式是单产品系的. 一个生产汽车的工厂,生产TopCar.TopBus,MidCar.MidBus,LowCar.LowBus. 利用抽象设计模式的方法,提取共同的特征. 当产生第四个SuperCar()类的时候,只需要在原来代码上增添SuperCar类实现接口,创建工厂即可. 而不需要再更改原来的代码. */ interface ICar{ //System.out.println("定义一些生产汽车共有的方法

接口和简单工厂设计模式

声明:本栏目所使用的素材都是凯哥学堂VIP学员所写,学员有权匿名,对文章有最终解释权:凯哥学堂旨在促进VIP学员互相学习的基础上公开笔记. 接口: 接口就是纯抽象类的演变,实现接口的类都必须实现接口的的方法.接口里全部都是方法的声明,没有方法的实现. 接口里的方法都是public修饰的,就算不写public关键字,也是默认public的,里面的申请的属性 全部都是public 静态常量,接口里没有构造器,静态块和实例块. 例如: 在c这种面向对象的编程语言中也有抽象类,但是要求的不严格,c要求的