Java设计模式编程中简单工厂与抽象工厂模式的使用实例

简单工厂模式
类图

通过一个工厂类,以一个条件来创建对应的对象

//业务功能
public interface ICalculation {
  double getResult(double numA, double numB);
} 

public class CalcAdd implements ICalculation { 

  @Override
  public double getResult(double numA, double numB) {
    System.out.println("加法");
    return numA + numB;
  } 

} 

public class CalcSubtract implements ICalculation { 

  @Override
  public double getResult(double numA, double numB) {
    System.out.println("减法");
    return numA - numB;
  } 

} 

/*
 * 简单工厂模式 关注:对象的创建
 * 建立一个工厂类,对实现了同一接口的或者是存在继承关系的一些类进行实例的创建
 */
public class Test4Simple {
  public static void main(String[] args) {
//   String operation = "/";
    String operation = "+";
//   String operation = "-";
//   String operation = "*";
    double numA = 182, numB = 33;
    ICalculation createCalc = CalcSimpleFactory.createCalc(operation);
    double result = createCalc.getResult(numA, numB);
    System.out.println(result);
  }
}

简单工厂的缺陷: 简单工厂创建产品时需要传递相应的参数,如果传递不正确就取不到对象了。
改进:多方法创建不同产品
类图

public class CalcMultipleFactory { 

  public static ICalculation produceAdd() {
    return new CalcAdd();
  } 

  public static ICalculation produceSubtract() {
    return new CalcSubtract();
  } 

  public static ICalculation produceMultiply() {
    return new CalcMultiply();
  } 

  public static ICalculation produceDivide() {
    return new CalcDivide();
  }
} 

public class Test4Multiple { 

  public static void main(String[] args) {
    double numA = 182, numB = 33; 

    ICalculation createCalc = CalcMultipleFactory.produceAdd();
    double result = createCalc.getResult(numA, numB);
    System.out.println(result); 

    createCalc = CalcMultipleFactory.produceSubtract();
    result = createCalc.getResult(numA, numB);
    System.out.println(result); 

    createCalc = CalcMultipleFactory.produceMultiply();
    result = createCalc.getResult(numA, numB);
    System.out.println(result); 

    createCalc = CalcMultipleFactory.produceDivide();
    result = createCalc.getResult(numA, numB);
    System.out.println(result);
  }
}

抽象工厂模式
里面有几个概念:抽象工厂、实体工厂、抽象产品、实体产品
抽象工厂:定义创建产品的抽象方法
实体工厂:具体的创建哪种产品
抽象产品:一个接口或基类
实体产品:实现具体功能,或派生
类图

//抽象产品1
public interface IProduct1 {
  public void show();
} 

//抽象产品2
public interface IProduct2 {
  public void show();
} 

//实体产品1
public class Product1 implements IProduct1 {
  public void show() {
    System.out.println("创建了1型产品");
  }
}  

//实体产品2
public class Product2 implements IProduct2 {
  public void show() {
    System.out.println("创建了2型产品");
  }
} 

/*
 * 1A 1B属于Product1 同一产品等级结构中
 * 2A 2B属于Product2
 */
public class GradeProduct1A extends Product1 { 

  @Override
  public void show() {
    super.show();
    System.out.println("这是产品1下的:产品A");
  } 

} 

public class GradeProduct1B extends Product1 { 

  @Override
  public void show() {
    super.show();
    System.out.println("这是产品1下的:产品B");
  }
} 

public class GradeProduct2A extends Product2 { 

  @Override
  public void show() {
    super.show();
    System.out.println("这是产品2下的:产品A");
  }
} 

public class GradeProduct2B extends Product2 { 

  @Override
  public void show() {
    super.show();
    System.out.println("这是产品2下的:产品B");
  }
} 

//抽象工厂 创建不同的抽象产品
public interface IFactory {
  public IProduct1 createProduct1A();//1类产品 型号A
  public IProduct1 createProduct1B();//1类产品 型号B
  public IProduct2 createProduct2A();//2类产品 型号A
  public IProduct2 createProduct2B();//2类产品 型号B
} 

//实体工厂 创建实体产品,返回类型为抽象产品
public class Factory implements IFactory { 

  public IProduct1 createProduct1A() {
    return new GradeProduct1A();
  } 

  public IProduct1 createProduct1B() {
    return new GradeProduct1B();
  } 

  public IProduct2 createProduct2A() {
    return new GradeProduct2A();
  } 

  public IProduct2 createProduct2B() {
    return new GradeProduct2B();
  }
} 

/*
 * 抽象工厂模式:用来创建一组相关或者相互依赖的对象
 *
 * 流程:抽象工厂,实体工厂   生产产品
 *   抽象产品,实体产品    实现产品功能
 * 缺点:当需要增加一个产品(由抽象和实体构成),工厂都需要更改
 */
public class Test4Abstract {
  public static void main(String[] args) {
    IFactory factory = new Factory();
    IProduct1 product1a = factory.createProduct1A();
    product1a.show();
    IProduct1 product1b = factory.createProduct1B();
    product1b.show(); 

    IProduct2 product2a = factory.createProduct2A();
    product2a.show();
    IProduct2 product2b = factory.createProduct2B();
    product2b.show();
  }
}
(0)

相关推荐

  • 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设计模式编程中的单例模式和简单工厂模式

    单例模式 动机 有时候只有一个类的实例是很重要的.比如,一个系统应该只有一个窗口管理实例. 单例模式是最简单设计模式:类负责实例化自己,确保只有一个实例,并且提供一个访问这个实例的入口. 目的 1. 确保只有一个实例被创建. 2. 提供访问这个实例的入口. 使用final确保被创建一次,private的构造函数确保不被实例化.public的getInstance方法确保外部能够访问.下面是饿汉模式: public class Singleton { private static final Si

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

    在编写一个计算器程序时,可以将业务逻辑和显示分离,业务逻辑封装为一个类(封装):如果要新添加一种运算,可以先创建一个Operation的基类,然后各种运算从Operation类继承,并实现GetResult()虚函数,这时添加新的运算只需要派生一个新的类,即不需要之前的运算参与编译.如何让计算器知道我是希望使用哪种运算呢?应该考虑单独的类来做这个创造实例的过程,这就是工厂.创建一个OperationFactory类,传入参数,函数createOperate就可以实例化出合适的对象. Java代码

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

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

  • 以Java代码为例讲解设计模式中的简单工厂模式

    1. 简单工厂模式简介 简单工厂模式(Simple Factory),又被称为"静态工厂方法模式".它属于"创建模式"(创建对象的模式),并且是"工厂方法"模式的一种特殊实现. 通常,我们利用简单工厂模式来进行类的创建.例如,获取线程池对象,就是通过简单工厂模式来实现的.它的结构图如下所示: 工厂:工厂是简单工厂模式的核心,提供了对外接口.客户端或其它程序要获取Product对象,都是通过Factory的接口来获取的. 抽象产品:抽象产品是(许多

  • Java设计模式编程中简单工厂与抽象工厂模式的使用实例

    简单工厂模式 类图 通过一个工厂类,以一个条件来创建对应的对象 //业务功能 public interface ICalculation { double getResult(double numA, double numB); } public class CalcAdd implements ICalculation { @Override public double getResult(double numA, double numB) { System.out.println("加法&q

  • Java设计模式编程中的工厂方法模式和抽象工厂模式

    工厂方法模式 动机 创建一个对象往往需要复杂的过程,所以不适合包含在一个复合工厂中,当有新的产品时,需要修改这个复合的工厂,不利于扩展. 而且,有些对象的创建可以需要用到复合工厂访问不到的信息,所以,定义一个工厂接口,通过实现这个接口来决定实例化那个产品,这就是工厂方法模式,让类的实例化推迟到子类中进行. 目的 1. 定义一个接口,让子类决定实例化哪个产品. 2. 通过通用接口创建对象. 实现 1. 产品接口和具体产品很好理解. 2. 工厂类提供一个工厂方法,返回一个产品对象.但是这个工厂方法是

  • 实例解析C#设计模式编程中简单工厂模式的使用

    简单工厂模式的介绍 说到简单工厂,自然的第一个疑问当然就是什么是简单工厂模式了? 在现实生活中工厂是负责生产产品的,同样在设计模式中,简单工厂模式我们也可以理解为负责生产对象的一个类, 我们平常编程中,当使用"new"关键字创建一个对象时,此时该类就依赖与这个对象,也就是他们之间的耦合度高,当需求变化时,我们就不得不去修改此类的源码,此时我们可以运用面向对象(OO)的很重要的原则去解决这一的问题,该原则就是--封装改变,既然要封装改变,自然也就要找到改变的代码,然后把改变的代码用类来封

  • C++设计模式编程中简单工厂与工厂方法模式的实例对比

    简单工厂模式实例 题目:实现计算器的输入2个数和运算符,得到结果 工程结构: (1)头文件 COperationFactory.h(运算符工厂类) (2)源文件 SimpleFactory.cpp(客户端应用类,主函数所在) (3)运算类 COperation.cpp(运算符基类) COperation.h COperationAdd.h(加法运算符子类,继承于COperation) COperationDiv.h (除法运算符子类,继承于COperation) COperationMul.h

  • 实例解析C++设计模式编程中简单工厂模式的采用

    简单工厂模式中专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类.它又称为静态工厂方法模式,属于类的创建型模式. 简单工厂模式的UML类图 简单工厂模式的程序通过封装继承来降低程序的耦合度,设计模式使得程序更加的灵活,易修该,易于复用. 简单工厂是在工厂类中做判断,从而创造相应的产品. 简单工厂模式的实质是由一个工厂类根据传入的参数,动态决定应该创建哪一个产品类(这些产品类继承自一个父类或接口)的实例.   该模式中包含的角色及其职责   1.工厂(Creator)角色  

  • 详解Java设计模式编程中的Flyweight享元模式的开发结构

    享元(Flyweight)模式:通过共享技术以便有效的支持大量细粒度的对象. 享元模式在阎宏的<java与模式>中分为单纯享元模式和复合享元模式,复合模式的复合享元是不可以共享的,享元对象能做到共享的关键是区分内蕴态(Internal State)和外蕴态( External State).这两个"蕴态"翻译的太难懂,我不是说翻译的不好,可能是我理解能力差,还是<Design Pattern Elements of Reusable Object-Oriented S

  • 详解Java设计模式编程中的策略模式

    定义:定义一组算法,将每个算法都封装起来,并且使他们之间可以互换. 类型:行为类模式 类图: 策略模式是对算法的封装,把一系列的算法分别封装到对应的类中,并且这些类实现相同的接口,相互之间可以替换.在前面说过的行为类模式中,有一种模式也是关注对算法的封装--模版方法模式,对照类图可以看到,策略模式与模版方法模式的区别仅仅是多了一个单独的封装类Context,它与模版方法模式的区别在于:在模版方法模式中,调用算法的主体在抽象的父类中,而在策略模式中,调用算法的主体则是封装到了封装类Context中

  • 对比Java设计模式编程中的状态模式和策略模式

    为了能在Java应用程序中正确的使用状态模式和策略模式,开发人员需要清楚地知道这两种模式之间的区别.尽管状态模式和策略模式的结构非常相似,它们又同样遵循开闭原则,都代表着SOLID设计原则的'O',但它们的意图是完全不同的.Java中的策略模式是对一组相关的算法进行封装,给调用方提供了运行时的灵活性.调用方可以在运行时选择不同的算法,而不用修改使用策略的那个Context类.使用策略模式的经典例子包括实现加密算法,压缩算法,以及排序算法.另一方面,状态模式使用一个对象可以在不同的状态下表现出不同

  • 讲解Java设计模式编程中的建造者模式与原型模式

    建造者模式 定义 又叫生成器模式,它可以将复杂对象的建造过程抽象出来(抽象类别),使这个抽象过程的不同实现方法可以构造出不同表现(属性)的对象. 当创建复杂对象的算法应该独立于该对象的组成部分时,而且构造过程必须允许被构造的对象有不同的表示时.我们可以考虑使用建造者模式. 实现 1. Builder为创建一个Product对象的各个部件指定抽象接口.通常包含创建产品和返回产品的抽象方法,也可以是具体方法,把创建过程放到ConcreteBuilder类中. 2. ConcreteBuilder 实

随机推荐