Java简单工厂模式详细解释

目录
  • 简单工厂模式概述
  • 简单工厂模式的结构与实现
    • 结构:
    • 实现
  • 简单工厂模式的简化
  • 简单工厂模式的优缺点和适用环境
    • 简单工厂模式的优点
    • 简单工厂模式的缺点
    • 简单工厂模式的适用环境
  • 简单案例
    • 题目:
    • UML:
    • 运行结果:
  • 总结

简单工厂模式概述

1.定义:定义一个工厂类,他可以根据参数的不同返回不同类的实例,被创建的实例通常都具有共同的父类

2.在简单工厂模式中用于被创建实例的方法通常为静态(static)方法,因此简单工厂模式又被成为静态工厂方法(Static Factory Method)

3.需要什么,只需要传入一个正确的参数,就可以获取所需要的对象,而无需知道其实现过程

4.例如,我开一家披萨店,当客户需要某种披萨并且我这家店里也能做的时候,我就会为其提供所需要的披萨(当然是要钱的哈哈),如果其所需的我这没有,则是另外的情况,后面会谈。这时候,我这家 披萨店就可以看做工厂(Factory),而生产出来的披萨被成为产品(Product),披萨的名称则被称为参数,工厂可以根据参数的不同返回不同的产品,这就是简单工厂模式

简单工厂模式的结构与实现

结构:

1.Factory(工厂):核心部分,负责实现创建所有产品的内部逻辑,工厂类可以被外界直接调用,创建所需对象

2.Product(抽象类产品):工厂类所创建的所有对象的父类,封装了产品对象的公共方法,所有的具体产品为其子类对象

3.ConcreteProduct(具体产品):简单工厂模式的创建目标,所有被创建的对象都是某个具体类的实例。它要实现抽象产品中声明的抽象方法(有关抽象类)

实现

abstract class Product
{
    public void MethName()
    {
        //公共方法的实现
    }
    public abstract void MethodDiff();
    //声明抽象业务方法
}
class ConcreteProductA : Product
{
    public override void MethodDiff()
    {
        //业务方法的实现
    }
}
class Factory
{
    public static Product GetProduct(string arg)
    {
        Product product =  null;
        if(arg.Equals("A")
        {
            product = new ConcreteProductA();
            //init
        }
        else if(arg.Equals("B"))
        {
            product = new ConcreteProductB();
            //init
        }
        else
        {
        ....//其他情况
        }
        return product;
    }
}
class Program
{
    static void Main(string[] args)
    {
        Product product;
        product = Factory.GetProduct("A");//工厂类创建对象
        Product.MethName();
        product.MethodDiff();
    }
}

简单工厂模式的简化

1.为了简化简单工厂模式,将抽象产品类和工厂类合并,将静态工厂方法移到抽象产品类中

客户端可以调用产品父类的静态工厂方法,根据不同的参数创建不同类型的产品子类对象。

简单工厂模式的优缺点和适用环境

简单工厂模式的优点

(1)工厂类包含必要的逻辑判断,可以决定在什么时候创建哪一个产品的实例。客户端可以免除直接创建产品对象的职责

(2)客户端无需知道所创建具体产品的类名,只需知道参数即可

(3)也可以引入配置文件,在不修改客户端代码的情况下更换和添加新的具体产品类。(这也是我在开始的披萨店里遇到没有的披萨的解决情况)

简单工厂模式的缺点

(1)工厂类集中了所有产品的创建逻辑,职责过重,一旦异常,整个系统将受影响

(2)使用简单工厂模式会增加系统中类的个数(引入新的工厂类),增加系统的复杂度和理解难度

(3)系统扩展困难,一旦增加新产品不得不修改工厂逻辑,在产品类型较多时,可能造成逻辑过于复杂

(4)简单工厂模式使用了static工厂方法,造成工厂角色无法形成基于继承的等级结构。

简单工厂模式的适用环境

(1)工厂类负责创建对的对象比较少,因为不会造成工厂方法中的业务逻辑过于复杂

(2)客户端只知道传入工厂类的参数,对如何创建对象不关心

简单案例

题目:

使用简单工厂模式设计一个可以创建不同几何图形(Shape),如Circle,Rectangle,Triangle等绘图工具类,每个几何图形均具有绘制Draw()和擦除Erase()两个方法要求在绘制不支持的几何图形时,抛出一个UnsuppShapeException异常,绘制类图并使用C#语言实现。

UML:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
/*使用简单工厂模式设计一个可以创建不同几何图形(Shape),如Circle,Rectangle,Triangle等绘图工具类,每个几何图形均具有绘制Draw()和擦除Erase()两个方法
 * 要求在绘制不支持的几何图形时,抛出一个UnsuppShapeException异常,绘制类图并使用C#语言实现。
*/
namespace SimpleShapeFactory
{
    public interface InShape//图形接口 抽象产品类
    {
        void Draw();
        void Erase();
    }
    public class Circle : InShape//圆形类,具体产品类
    {
        private static int count;   //生成图形计数
        string radious;
        public Circle()//构造
        {
            Console.WriteLine("Create Circle");
            Console.WriteLine("Input the radious of Circle:");
            radious = Console.ReadLine();
        }
        public void Draw()//实现接口方法
        {
            int Radious = int.Parse(radious);
            Console.WriteLine("Display circle " + (++count) +" information:");
            Console.WriteLine("Circle "+ count+ " circumference:" + 2 * Radious * 3.14159);
            Console.WriteLine("Circle "+ count+" area:" + 3.14159 * Radious * Radious);
        }
        public void Erase()//实现接口方法
        {
            while (true)
            {
                Console.WriteLine("Erase current shape(y/n)?");
                string choose;
                choose = Console.ReadLine();
                if (choose.Equals("y") || choose.Equals("Y"))
                {
                    Console.WriteLine("Erase Circle "+count +" successfully!");
                    count--;
                    break;
                }
                else if (choose.Equals("n") || choose.Equals("N"))
                {
                    Console.WriteLine("Circle "+ count+" successfully saved!");
                    break;
                }
                else
                {
                    Console.WriteLine("Input error, re-enter!");
                }
            }
        }
    }
    class Rectangle : InShape//矩形类,具体产品类
    {
        private static int count = 0;//生成图形计数
        string length;
        string wideth;
        public Rectangle()//构造
        {
            Console.WriteLine("Create Rectangle");
            Console.WriteLine("Input the length and wideth of Rectangle:");
            length = Console.ReadLine();
            wideth = Console.ReadLine();
        }
        public void Draw()//实现接口方法
        {
            int Length = int.Parse(length);
            int Wideth = int.Parse(wideth);
            Console.WriteLine("Display rectangle " + (++count) + " information:");
            Console.WriteLine("Rectangle "+ count + "circumference:" + 2 * Length * Wideth);
            Console.WriteLine("Rectangle "+ count + "area:" + Length * Wideth);
        }
        public void Erase()//实现接口方法
         {
             while (true)
             {
                 Console.WriteLine("Erase current shape(y/n)?");
                 string choose;
                 choose = Console.ReadLine();
                 if (choose.Equals("y") || choose.Equals("Y"))
                 {
                     Console.WriteLine("Erase rectangle "+count+ "successfully!");
                     --count;
                     break;
                 }
                 else if (choose.Equals("n") || choose.Equals("N"))
                 {
                     Console.WriteLine("Rectangle "+ count+" successfully saved!");
                     break;
                 }
                 else
                 {
                     Console.WriteLine("Input error, re-enter!");
                 }
             }
        }
    }
    class Triangle : InShape//三角形类,具体产品类
    {
        private static int count = 0;//生成图形计数
        string lengtha;
        string lengthb;
        string lengthc;
        public Triangle()//构造
        {
            Console.WriteLine("Create Triangle");
            Console.WriteLine("Input the lengtha ,lengthb and lengthc of Triangle:");
            lengtha = Console.ReadLine();
            lengthb = Console.ReadLine();
            lengthc = Console.ReadLine();
        }
        public void Draw()//实现接口方法
        {
            int Lengtha = int.Parse(lengtha);
            int Lengthb = int.Parse(lengthb);
            int Lengthc = int.Parse(lengthc);
            if ((Lengtha + Lengthb > Lengthc) && (Lengtha + Lengthc > Lengthb) && (Lengthb + Lengthc > Lengtha))
            {
                double S = (Lengtha + Lengthb + Lengthc) * 0.5;
                double area = Math.Sqrt(S * (S - Lengtha) * (S - Lengthb) * (S - Lengthc));
                Console.WriteLine("Display triangle "+ (++count)+" information:");
                Console.WriteLine("Triangle " + count +" circumference:" + (Lengtha + Lengthb + Lengthc));
                Console.WriteLine("Triangle "+ count +" area:" + area);
                Erase();
            }
            else
            {
                Console.WriteLine("Create triangle failed!");
            }
        }
        public void Erase()//实现接口方法
         {
             while (true)
             {
                 Console.WriteLine("Erase shape(y/n)?");
                 string choose;
                 choose = Console.ReadLine();
                 if (choose.Equals("y") || choose.Equals("Y"))
                 {
                     Console.WriteLine("Erase tirangle " +count +" successfully!");
                     --count;
                     break;
                 }
                 else if (choose.Equals("n") || choose.Equals("N"))
                 {
                     Console.WriteLine("Triangle "+ count +" successfully saved!");
                     break;
                 }
                 else
                 {
                     Console.WriteLine("Input error, re-enter!");
                 }
             }
        }
    }
    class ShapeFactory//图形工厂类,充当工厂类
    {
        public static  InShape Getshape(string type)//静态工厂方法
        {
            InShape shape;
            shape = null;
            if (type.Equals("Circle"))
            {
                shape = new Circle();
                Console.WriteLine("Init set Circle");
                shape.Draw();
                shape.Erase();
            }
            else if(type.Equals("Rectangle"))
            {
                shape = new Rectangle();
                Console.WriteLine("Init set Rectangle");
                shape.Draw();
                shape.Erase();
            }
            else if (type.Equals("Triangle"))
            {
                shape = new Triangle();
                Console.WriteLine("Init set Triangle");
                shape.Draw();
            }
            else//异常 这里我应该声明调用异常处理类的,那样会更好些
            {
                Console.WriteLine("UnsupportShapeException!");
                Console.WriteLine("Emotional reminders :Pay 1 million$ to Alipay:132****6151 can create every shape you want!!! ");
            }
            return shape;
        }
    }
    class Program//客户端测试类
    {
        static void Main(string[] args)
        {
            while (true)
            {
                InShape shape;
                Console.WriteLine("Please input the shape you want to create");
                string str = Console.ReadLine();
                shape = ShapeFactory.Getshape(str);//通过静态工厂方法创建产品
                Console.ReadLine();
            }
        }
    }
}

运行结果:

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注我们的更多内容!

(0)

相关推荐

  • 详解Java实践之抽象工厂模式

    目录 一.前言 二.开发环境 三.抽象工厂模式介绍 四.案例场景模拟 4.1.场景模拟工程 4.2.场景简述 4.2.1.模拟单机服务 RedisUtils 4.2.2.模拟集群 EGM 4.2.3.模拟集群 IIR 4.3.单集群代码使用 4.3.1.定义使用接口 4.3.2.实现调用代码 五.代码实现 5.1.工程结构 5.2.ifelse实现需求 5.3.测试验证 六.抽象工厂模式重构代码 6.1.工程结构 6.2.代码实现 6.2.1.定义适配接口 6.2.2.实现集群使用服务 6.2.

  • Java设计模式之抽象工厂模式详解

    一.什么是抽象工厂模式 为创建一组相关或相互依赖的对象提供一个接口,而且无需指定他们的具体类,这称之为抽象工厂模式(Abstract Factory).我们并不关心零件的具体实现,而是只关心接口(API).我们仅使用该接口(API)将零件组装称为产品. 二.示例程序   1.抽象的零件:Item类 package com.as.module.abstractfactory; /** * 抽象的零件 * @author Andy * @date 2021/4/29 23:16 */ public

  • java设计模式--三种工厂模式详解

    目录 简单工厂 代码: 1.产品接口 2.产品接口实现子类 3.简单工厂类 4.调用工厂 5.测试 工厂方法 代码: 1.工厂接口 2.工厂实现子类 3.产品接口 4.产品实现子类 5.调用 6.测试 1.产品接口 2.产品抽象子类-普通产品 抽象工厂 3.1产品抽象子类-魔法产品 4.工厂接口 5.工厂实现子类-普通工厂 6.工厂实现子类-魔法工厂 7.调用 8.测试 总结 简单工厂 简单工厂模式是属于创建型模式,是工厂模式的一种.简单工厂模式是由一个工厂对象决定创建出哪一种产品类的实例.定义

  • Java使用抽象工厂模式实现的肯德基消费案例详解

    本文实例讲述了Java使用抽象工厂模式实现的肯德基消费案例.分享给大家供大家参考,具体如下: 一.模式定义 抽象工厂模式提供了一个接口,用于创建相关或者依赖对象的家族,而不需要指定具体实现类. 抽象工厂模式允许客户使用抽象接口来创建一组相关的产品,客户类和工厂类分开,客户需要任何产品的时候,只需要向工厂请求即可,客户无须修改就可以获得新产品. 二.模式举例 1 模式分析 我们借用爸爸和儿子到肯德基店消费这一场景来说明这一模式,进行抽象分析后的截图如下 2 抽象工厂模式的静态建模 3 代码示例 3

  • Java设计模式之工厂模式实现方法详解

    本文实例讲述了Java设计模式之工厂模式实现方法.分享给大家供大家参考,具体如下: 工厂模式主要是为创建对象提供过渡接口,以便将创建对象的具体过程屏蔽隔离起来,达到提高灵活性的目的 工厂模式在分为三类: 1)简单工厂模式(Simple Factory):不利于产生系列产品: 2)工厂方法模式(Factory Method):又称为多形性工厂: 3)抽象工厂模式(Abstract Factory):又称为工具箱,产生产品族,但不利于产生新的产品: 一.简单工厂模式 简单工厂模式又称静态工厂方法模式

  • java设计模式之简单工厂模式详解

    简单工厂模式:由一个工厂对象决定创建出哪一种类的实例. 1.抽象类 public abstract class People { public abstract void doSth(); } 2.具体类 public class Man extends People{ @Override public void doSth() { System.out.println("I'm a man,I'm coding."); } } 3.具体类 public class Girl exte

  • Java简单工厂模式详细解释

    目录 简单工厂模式概述 简单工厂模式的结构与实现 结构: 实现 简单工厂模式的简化 简单工厂模式的优缺点和适用环境 简单工厂模式的优点 简单工厂模式的缺点 简单工厂模式的适用环境 简单案例 题目: UML: 运行结果: 总结 简单工厂模式概述 1.定义:定义一个工厂类,他可以根据参数的不同返回不同类的实例,被创建的实例通常都具有共同的父类 2.在简单工厂模式中用于被创建实例的方法通常为静态(static)方法,因此简单工厂模式又被成为静态工厂方法(Static Factory Method) 3

  • Java简单工厂模式定义与用法实例分析

    本文实例讲述了Java简单工厂模式定义与用法.分享给大家供大家参考,具体如下: 一 代码 // 抽象产品(Abstract Product)角色 interface Block { public void print(); } // 具体产品角色 class IBlock implements Block { public void print() { System.out.println("我是一个I形的方块!"); } } // 具体产品角色 class LBlock implem

  • java简单工厂模式实例及讲解

    简单工厂模式 工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一.这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式.在工厂模式中,我们在创建对象时不会对客户端暴露创建逻辑,并且是通过使用一个共同的接口来指向新创建的对象. 介绍 意图:定义一个创建对象的接口或者抽象类,让其子类自己决定实例化哪一个工厂类,工厂模式使其创建过程延迟到子类进行. 主要解决:主要解决接口选择的问题. 何时使用:我们明确地计划不同条件下创建不同实例时. 如何解决:让其子类实现工厂

  • JAVA简单工厂模式(从现实生活角度理解代码原理)

    简单工厂模式(Simple Factory),说他简单是因为我们可以将此模式比作一个简单的民间作坊,他们只有固定的生产线生产固定的产品.也可以称他为静态工厂设计模式,类似于之前提到过静态代理设计模式,一条生产线生产一种产品(一个代理代理一种业务),为了方便大家理解,我们将KFC比作一个简单的工厂,实现代码如下: //建造接口(或者抽象类)提供食物生产方法 interface Food{ public abstract void get(); } //汉堡类(后厨生产线)来实现食物生产方法 cla

  • java简单工厂模式入门

    目录 前言 试例 1. 创建饮料接口(或者抽象类) 2. 具体饮料类的实现(可乐.雪碧) 3. 饮料生产工厂类 4. 工厂调用 总结 前言 定义一个工厂类,他可以根据参数的不同返回不同类的实例,被创建的实例通常都具有共同的父类 在简单工厂模式中用于被创建实例的方法通常为静态(static)方法,因此简单工厂模式又被成为静态工厂方法(Static Factory Method) 只需要传入一个正确的参数,就可以获取所需要的对象,而无需知道其实现过程 试例 以饮料加工厂为例 1. 创建饮料接口(或者

  • Java 设计模式以虹猫蓝兔的故事讲解简单工厂模式

    目录 专栏介绍 本期介绍 什么是简单工厂模式 优点 缺点 应用场景 简单工厂的实现 专栏介绍 本系列专栏会以虹猫蓝兔七侠传的故事为例来给大家详细分析所有模式,希望能给大家带来帮助! 本期介绍 模式: 简单工厂模式 案例: 一个天外陨石(抽象产品),三把剑(产品), 一个铸剑师(工厂). 虹猫蓝兔莎莉分别找铸剑师造了三把剑. 什么是简单工厂模式 工厂模式的定义: 定义一个创建产品对象的工厂接口,将产品对象的实际创建工作推迟到具体子工厂类当中.这满足创建型模式中所要求的"创建与使用相分离"

  • Java十分钟精通进阶简单工厂模式

    目录 1.什么是工厂模式? 工厂模式的定义: 2.简单工厂模式优点和缺点 3.简单工厂的代码实现 4.小结 1.什么是工厂模式? 工厂模式的定义: 定义一个创建产品对象的工厂接口,将产品对象的实际创建工作推迟到具体子工厂类当中.这满足创建型模式中所要求的"创建与使用相分离"的特点. 现实生活中,原始社会自给自足(没有工厂),农耕社会小作坊(简单工厂,民间酒坊),工业革命流水线(工厂方法,自产自销),现代产业链代工厂(抽象工厂,富士康.我们可以看到工厂的变化趋势,但是对于我们来说,看到是

  • Java 深入探究讲解简单工厂模式

    目录 1. 简单工厂介绍 2. 简单工厂类图UML 3. 简单工厂角色说明 4. 代码实现 5. 优缺点 6. 使用场景 1. 简单工厂介绍 简单工厂有一个具体的工厂类,可以生产不同的产品,属于创建型设计模式. 注意:简单工厂模式 不属于23种设计模式之列 2. 简单工厂类图UML 3. 简单工厂角色说明 简单工厂(SimpleFactory):是简单工厂模式的核心,负责实现创建所有实例的内部逻辑,工厂类的创建产品类的方法可以被外界直接访问,创建所需的产品对象. 抽象产品(Product):是简

  • 简单工厂模式_动力节点Java学院整理

    简单工厂模式解释:  简单工厂模式(Simple Factory Pattern)属于类的创新型模式,又叫静态工厂方法模式(Static FactoryMethod Pattern),是通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类. 简单工厂模式的UML图:  简单工厂模式中包含的角色及其相应的职责如下:        工厂角色(Creator):这是简单工厂模式的核心,由它负责创建所有的类的内部逻辑.当然工厂类必须能够被外界调用,创建所需要的产品对象.      

  • java设计模式之简单工厂模式简述

    简单工厂模式的概念 就是建立一个工厂类,对实现了同一接口的一些类进行实例的创建.简单工厂模式的实质是由一个工厂类根据传入的参数,动态决定应该创建哪一个产品类(这些产品类继承自一个父类或接口)的实例. 简单工厂模式的UML图 简单工厂模式代码 学习简单工厂模式的时候我用的是一个与人类有相关的例子.人类在世界分为男人和女人,首先定义一个Human产品的抽象接口 /** * This is factory patter package */ package com.roc.factory; /** *

随机推荐