Java常见设计模式之工厂模式

工厂模式在我们日常的应用中应当算是比较广泛的一种设计模式了。今天让我们一起来学习一下,工厂的设计模式。

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

      1、简单工厂模式     
     简单工厂模式又称为静态工厂,在简单工厂模式中,一个工厂类处于对产品类实例化调用的中心位置上,它决定那一个产品类应当被实例化, 如同一个交通警察站在来往的车辆流中,决定放行那一个方向的车辆向那一个方向流动一样。

先来看看它的组成:
      1) 工厂类角色:这是本模式的核心,含有一定的商业逻辑和判断逻辑。在java中它往往由一个具体类实现。
      2) 抽象产品角色:它一般是具体产品继承的父类或者实现的接口。在java中由接口或者抽象类来实现。
      3) 具体产品角色:工厂类所创建的对象就是此角色的实例。在java中由一个具体类实现。

使用Java代码实现相关内容:

有一个农场公司,专门向市场销售各类水果。有如下水果:
     ● 葡萄(grape)
     ● 草莓(strawberry)
     ● 苹果(apple)

package com.yonyou.factory;

/**
 * 水果通用接口函数
 * @author 小浩
 * @创建日期 2015-4-6
 */
public interface Fruit
{
/**
* 水果与其它植物相比有一些专门的属性,以便与农场的
* 其它植物区分开。这里的水果假设它必须具备的方法:
* 生长grow()、收获harvest()、种植plant()
*/
void grow();
void harvest();
void plant();
}

  

package com.yonyou.factory;

/**
 * 苹果的实现类
 * @author 小浩
 * @创建日期 2015-4-6
 */
public class Apple implements Fruit
{
/**
* 苹果是水果类的一种,因此它必须实现水果接口的所有方法。即
* grow()、harvest()、plant()三个函数。另外,由于苹果是多年生植物,
* 所以多出一个treeAge性质,描述苹果的树龄。
*/

private int treeAge;
//苹果的生长函数代码
public void grow() {}
//苹果的收获函数代码
public void harvest() {}
//苹果的种植函数代码
public void plant() {}

public int getTreeAge() { return treeAge; }
public void setTreeAge(int treeAge) { this.treeAge = treeAge; }
}

  

package com.yonyou.factory;
/**
 * 草莓的实体类
 * @author 小浩
 * @创建日期 2015-4-6
 */
public class Strawberry implements Fruit
{
/**
* 草莓是水果类的一种,因此它必须实现水果接口的所有方法。即
* grow()、harvest()、plant()三个函数。另外,这里假设草莓分为大棚草莓和一般
* 草莓(即没有棚的草莓)。因此草莓比一般水果多出一个性质coteless,描述草莓
* 是大棚草莓还是没有大棚的草莓
*/

private boolean coteless;
//草莓的生长函数代码
public void grow() {}
//草莓的收获函数代码
public void harvest(){}
//草莓的种植函数代码
public void plant() {}
public boolean getCoteless() { return coteless; }
public void setCoteless(boolean coteless) { this. coteless = coteless; }

}

  

package com.yonyou.factory;

/**
 * 下面是Grape类的函数Grape.java:
 * @author 小浩
 * @创建日期 2015-4-6
 */
public class Grape implements Fruit
{
/**
* 葡萄是水果类的一种,因此它必须实现水果接口的所有方法。即
* grow()、harvest()、plant()三个函数。另外,由于葡萄分为有籽和无籽
* 两种,因此多出一个seedless性质,描述葡萄有籽还是无籽。
*/
private boolean seedless;
//葡萄的生长函数代码
public void grow() {}
//葡萄的收获函数代码
public void harvest(){}
//葡萄的种植函数代码
public void plant() {}

public boolean getSeedless() { return seedless; }
public void setSeedless(boolean seedless) { this.seedless = seedless; }

}

农场的园丁也是系统的一部分,自然要有一个合适的类来代表,我们用FruitGardener类
     来表示。FruitGardener类会根据客户端的要求,创建出不同的水果对象,比如苹果(apple),
     葡萄(grape)或草莓(strawberry)的实例。代码如下所示:

package com.yonyou.factory;

/**
 * 园丁工厂类
 * @author 小浩
 * @创建日期 2015-4-6
 */
public class FruitGardener
{
/**
* 通过下面的表态工厂方法,可以根据客户的需要,创建出不同的水果对象
* 如果提供的参数是“apple”则通过“return new Apple()”创建出苹果实例
* 如果是提供的参数是“grape”则创建葡萄实例,这正是简单工厂方法之精髓
*/
public static Fruit factory(String which)
{
if (which.equalsIgnoreCase("apple")) {
	return new Apple();
	}
else if(which.equalsIgnoreCase("strawberry")){
	return new Strawberry();
	}
else if(which.equalsIgnoreCase("grape")){
	return new Grape();
	}
else
return null;
 }
}

  

2、工厂方法模式

     工厂方法模式是简单工厂模式的进一步抽象化和推广,工厂方法模式里不再只由一个工厂类决定那一个产品类应当被实例化,这个决定被交给抽象工厂的子类去做。
  来看下它的组成:
      1)抽象工厂角色: 这是工厂方法模式的核心,它与应用程序无关。是具体工厂角色必须实现的接口或者必须继承的父类。在java中它由抽象类或者接口来实现。
      2)具体工厂角色:它含有和具体业务逻辑有关的代码。由应用程序调用以创建对应的具体产品的对象。
      3)抽象产品角色:它是具体产品继承的父类或者是实现的接口。在java中一般有抽象类或者接口来实现。
      4)具体产品角色:具体工厂角色所创建的对象就是此角色的实例。在java中由具体的类来实现。
      工厂方法模式使用继承自抽象工厂角色的多个子类来代替简单工厂模式中的“上帝类”。正如上面所说,这样便分担了对象承受的压力;而且这样使得结构变得灵活 起来——当有新的产品(即暴发户的汽车)产生时,只要按照抽象产品角色、抽象工厂角色提供的合同来生成,那么就可以被客户使用,而不必去修改任何已有的代 码。可以看出工厂角色的结构也是符合开闭原则的!

Java代码实现工厂方法的设计模式

由于水果接口以及grape类、strawberry类、apple类的代码都和上面的一样的。下面主要讲解不一样的部分。

下面的源码就是工厂方法模式的重点了,在简单工厂模式中,将这里将FruitGardener定义为一个类,即园丁要管理园里的所有水果,如果园丁哪天病了,水果都不能管理了。在工厂方法模式中将FruitGardener定义为一个接口,而将管理水果的角色划分得更细,比如有“葡萄园丁”、“草莓园丁”、“苹果园丁”等等。具体角色实现FruitGardener接口的工厂方法。源码如下所示:

package com.yonyou.factory;

/**
 * 园丁工厂通用接口
 * @author 小浩
 * @创建日期 2015-4-6
 */
public interface FruitGardener
{
   Fruit factory();
}

  

package com.yonyou.factory;

/**
 * 生产苹果的专用工厂
 * @author 小浩
 * @创建日期 2015-4-6
 */
public class AppleGardener implements FruitGardener{

	@Override
	public Fruit factory() {
        return new Apple();
	}
}

  

package com.yonyou.factory;

/**
 * 生产草莓的专用工厂
 * @author 小浩
 * @创建日期 2015-4-6
 */
public class StrawberryGardener implements FruitGardener{

	@Override
	public Fruit factory() {
		return new Strawberry();
	}

}

  

package com.yonyou.factory;

/**
 * 生产葡萄的专用工厂
 * @author 小浩
 * @创建日期 2015-4-6
 */
public class GrapeGardener implements FruitGardener{

	@Override
	public Fruit factory() {
		return new Grape();
	}

}

  

由以上源码可以看出,使用工厂方法模式保持了简单工厂模式的优点,克服了其缺点。当在系统中引入新产品时,既不必修改客户端,又不必修改具体工厂角色。可以较好的对系统进行扩展。但是当产品种类非常多时,会出现大量的与之对应的工厂对象,这不是我们所希望的。这样我们就引入的抽象工厂的概念了。

工厂方法模式和简单工厂模式在定义上的不同是很明显的。工厂方法模式的核心是一个抽象工厂类,而不像简单工厂模式, 把核心放在一个实类上。工厂方法模式可以允许很多实的工厂类从抽象工厂类继承下来, 从而可以在实际上成为多个简单工厂模式的综合,从而推广了简单工厂模式。
反过来讲,简单工厂模式是由工厂方法模式退化而来。设想如果我们非常确定一个系统只需要一个实的工厂类, 那么就不妨把抽象工厂类合并到实的工厂类中去。而这样一来,我们就退化到简单工厂模式了。

3.抽象工厂模式

抽象工厂:意的意图在于创建一系列互相关联或互相依赖的对象。<<Java设计模式>>

我自己觉得抽象工厂是在工厂方法的基础上引进了分类管理的概念....工厂方法用来创建一个产品,它没有分类的概念,而抽象工厂则用于创建一系列产品,所以产品分类成了抽象工厂的重点。

现在工厂再次大发展,要引进塑料大棚技术,在大棚里种植热带(Tropical)和亚热带的水果和蔬菜(Veggie)。其中水果分为TropicalFruit和NorthernFruit,蔬菜分为TropicalVeggie和NorthernVeggie。园丁包括TropicalGardener和NorthernGardener。也就是说,TropicalGardener专门管理TropicalFruit和TropicalGardener,NorthernGardener专门管理NorthernFruit和NorthernVeggie。

抽象工厂模式在这个例子中的源码如下所示:

时间: 2024-12-21 02:18:23

Java常见设计模式之工厂模式的相关文章

java常用设计模式之 工厂模式

工厂模式: 定义 一个用于创建对象的接口,让子类决定实例化哪一个类. 一句话概括: 是一个类的实例化延迟到其子类.     适用于 以下情况: ①:当一个类 ,不知道它所必须创建的对象的类的时候. ②:当一个类,希望由它的子类来指定它所创建的对象的时候. ③:当类将创建对象的职责给多个帮助子类中的一个,并且希望将哪一个帮助子类是代理这一信息局部化的时候. 说明: ① Product :定义工厂方法所创建的对象的接口. ② ConcreteProduct:实现Product 接口. ③ Creat

Java与设计模式-抽象工厂模式

首先说明,文章较长,保证你有耐心看完肯定能懂,没耐心直接点×即可. 抽象工厂模式,是创建型设计模式之一.抽象型工厂模式适合产品确定,产品线不确定的类型,怎么讲?通过一个具体例子来讲一下吧.例如某电脑厂商要生产电脑,也就是电脑这个产品确定,而电脑配置不确定,这种情况可以用抽象工厂模式来解决.类图如图所示: 代码实现完全结合UML类图,结合图就可以完成系统创建. 本实例里是抽象类ComputerFactory(对应UML类图中的AbstractFactory): package com.factor

java GOF23设计模式-简单工厂模式

public class CarFactory { //简单工厂模式1 public Car createCar(String type) { if(type.equals("奥迪")) { return new Audi(); }else if(type.equals("比亚迪")) { return new Byadi(); } return null; } //或简单工厂模式2 public static Car createAudi() { return n

Java常见设计模式之代理模式

指由一个代理主题来操作真实主题,真实主题执行具体的业务操作,而代理主题负责其它相关业务的处理.比如生活中的通过代理访问网络,客户通过网络代理连接网络(具体业务),由代理服务器完成用户权限和访问限制等与上网相关的其他操作(相关业务).代理的思想在我们日常生活中无处不在.下面我通过一个简单的代码先大致了解一下代理的相关内. 示例代码如下: package com.yonyou.test; /** * 创建一个上网的接口 * @author 小浩 * @创建日期 2015-4-6 */ public

java GOF23设计模式-简单工厂模式进阶

不修改已有代码,而是添加代码不和所有类打交道,只和总接口的实现类打交道public class Cilent { public static void main(String[] args) { Car c1=new AudiFactory().createCar(); Car c2=new ByadiFactory().createCar(); Car c3=new BenzFactory().createCar(); c1.run(); c2.run(); c3.run(); } } 接口:

浅析JAVA设计模式之工厂模式(一)

1 工厂模式简介 工厂模式的定义:简单地说,用来实例化对象,代替new操作. 工厂模式专门负责将大量有共同接口的类实例化.工作模式可以动态决定将哪一个类实例化,不用先知道每次要实例化哪一个类. 工厂模式可以分一下三种形态: 简单工厂 (Simple Factory)模式:又称静态工厂模式(StaticFactory). 工厂方法 (Factroy Method)模式:又称多态性工厂模式(Polymorphic Factory). 抽象工厂 (Abstract Factroy)模式:又称工具箱模式

浅析JAVA设计模式之工厂模式(二)

1 工厂方法模式简介 工厂方法 (Factroy Method) 模式:又称多态性工厂模式(Polymorphic Factory),在这种模式中,核心工厂不再是一个具体的类,而是一个抽象工厂,提供具体工厂实现的接口,具体创建产品交由子工厂去做,抽象工厂不涉及任何产品被实例化的细节.而不同等级的产品,就对应一个不同等级的工厂,如下图. 图1 1.1工厂方法模式(多态性工厂模式): 工厂方法模式有三个角色: 1. 抽象产品接口 2. 具体产品类 3. 抽象工厂接口 4.具体工厂类. 1.2工厂方法

浅析JAVA设计模式之工厂模式(三)

在阅读本文之前,请先阅读(一)和(二)中的简单工厂模式和工厂方法模式. 1抽象工厂模式简介 抽象工厂 (Abstract Factroy) 模式:工具箱模式(kit).抽象工厂模式是所有形态的工厂模式中最为抽象和最具一般性的一种形态,如下图. 图1.1 上图左边有一个工厂类的等级结构,右边有两个不同的产品等级结构,分别是产品A的等级结构和产品B的等级结构,工厂1和工厂2分别负责不同一个产品等级,同一个产品族的产品的生产.又例如下图: 图1.2 上图表示的是Button和Text两个不同产品的等级

Java研究之学习设计模式-简单工厂模式详解

 简介: 从设计模式的类型上来说,简单工厂模式是属于创建型模式,又叫做静态工厂方法(Static Factory Method)模式,但不属于23种GOF设计模式之一.简单工厂模式是由一个工厂对象决定创建出哪一种产品类的实例. 类图: 从UML类图中,可以看出,简单工厂模式的意思,就是把一个类内部,需要生成的部分,提取出来,变为一个工厂,通过工厂来new对象. 假设我们要吃苹果了,我们可以在代码中new一个苹果出来:当我们需要吃香蕉了,我们在代码中new一个香蕉出来.这种做法你会不会觉得麻烦