1. 使用设计模式的好处:可提高代码的重复性,让代码更容易被他人理解,保证代码的可靠性。

2. 工厂模式定义:就是创建一个工厂类来创建你需要的类,工厂模式包括工厂模式和抽象工厂模式,抽象工厂模式是工厂模式的扩展。

3. 工厂模式意图:定义一个接口来创建对象,但是让子类来决定哪些类需要被实例化,工厂方法把实例化工作推迟到子类中去实现。

4. 工厂方法适合场景:

<1>. 有一组类似的对象需要创建

<2>. 在编码时不能预见需要创建哪种类的实例

<3>. 系统需要考虑扩展性,不应依赖产品类实例如何被创建、组合和表达的细节

5. 工厂方法类图:

代码实现,举个例子,以一汽大众汽车工厂为例,大家都知道,一汽大众可生产多款汽车,有速腾、高尔夫、CC、宝来等等,我们就是使用工厂来创建不同款式的汽车。

<1>. 创建汽车接口,该接口就有一个生产汽车抽象。

package com.dasauto.car;

/**
* 一汽大众汽车接口
* @author DuanCZ
*/ public interface ICar { /**
* 生产汽车
*/
public void createCar(); }

<2>. 创建速腾汽车实现类,该类实现汽车接口

package com.dasauto.car;

public class SagitarCar implements ICar {

	/**
* 生产速腾汽车
*/
public void createCar() { System.out.println("-----------生产一台速腾汽车---------");
} }

<3>,创建高尔夫汽车实现类,该类实现汽车接口

package com.dasauto.car;

public class GolfCar implements ICar {

	/**
* 生产高尔夫汽车
*/
public void createCar() {
System.out.println("----------创建一台高尔夫汽车----------");
} }

<4>, 创建汽车工厂类,该类将根据不同款式的汽车类名称来实例化对象

package com.dasauto.car;

public class CarFactory {

	/**
* 根据类名称去创建汽车对象
* @param className
* @return
*/
public ICar getCar(String className){ try {
ICar car = (ICar) Class.forName(className).newInstance();
return car;
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
} }

<5>, 模拟客户端,测试

package com.dasauto.car;

public class CarClient {

	public static void main(String[] args) {

		CarFactory carFactory = new CarFactory();
ICar car = carFactory.getCar("com.dasauto.car.SagitarCar");
car.createCar();
} }

工厂方法模式很简单,就是单一的一种产品,这不同汽车类名称可以配置到xml中去,如果以后多了一种汽车,那么就是编写好实现类后,配置个XML文件,这样客户端就可以很简单的应用了。

6. 抽象工厂方法类图

相比工厂方法模式,抽象工厂就复杂一些了,它有产品族的概念,也就是说不是生产单一产品了,而是生产一系列产品。

代码实现,例如我们做一款程序,程序可能使用多种不同的数据库来完成数据持久化操作。下面是根据模型模拟代码

<1>,

package com.dcz.demo;

/**
* 抽象产品A
* @author DuanCZ
*/ public interface IProductA { public void method_1(); public void method_2(); }

<2>,

package com.dcz.demo;

/**
* 抽象产品B
* @author DuanCZ
*/
public interface IProductB { public void method_1(); public void method_2(); }

<3>,

package com.dcz.demo;

public interface IAbstractFactory {

	public IProductA productA();

	public IProductB productB();

}

<4>,

package com.dcz.demo;

public class concretenessProductA1 implements IProductA {

	@Override
public void method_1() { System.out.println("生产等级为1的A类Method_1");
} @Override
public void method_2() { System.out.println("生产等级为1的A类Method_2");
} }

<5>,

package com.dcz.demo;

public class concretenessProductA2 implements IProductA {

	@Override
public void method_1() { System.out.println("生产等级为2的A类Method_1");
} @Override
public void method_2() { System.out.println("生产等级为2的A类Method_2");
} }

<6>,

package com.dcz.demo;

public class concretenessProductB1 implements IProductB {

	@Override
public void method_1() {
System.out.println("生产等级为1的B类Method_1");
} @Override
public void method_2() {
System.out.println("生产等级为1的B类Method_2");
} }

<7>,

package com.dcz.demo;

public class concretenessProductB2 implements IProductB {

	@Override
public void method_1() {
System.out.println("生产等级为2的B类Method_1");
} @Override
public void method_2() {
System.out.println("生产等级为2的B类Method_2");
} }
<8>,
package com.dcz.demo;

public class ConcreateFactory1 implements IAbstractFactory {

	public IProductA productA() {
return new concretenessProductA1();
} public IProductB productB() {
return new concretenessProductB1();
} }
<9>,
package com.dcz.demo;

public class ConcreateFactory2 implements IAbstractFactory {

	@Override
public IProductA productA() {
return new concretenessProductA2();
} @Override
public IProductB productB() {
return new concretenessProductB2();
} }

<10>,
package com.dcz.demo;

public class Client {

	public static void main(String[] args) {
IAbstractFactory concreateFactory1 = new ConcreateFactory1();
IProductA productA = concreateFactory1.productA();
productA.method_1();
productA.method_2();
}
}

设计原则: 要依赖抽象,不要依赖具体类

Java设计模式 之 工厂方法模式的更多相关文章

  1. Java设计模式之工厂方法模式(转) 实现是抽象工厂?

    Java设计模式之工厂方法模式 责任编辑:覃里作者:Java研究组织   2009-02-25   来源:IT168网站   文本Tag: 设计模式 Java [IT168 技术文章]         ...

  2. Java设计模式系列-工厂方法模式

    原创文章,转载请标注出处:<Java设计模式系列-工厂方法模式> 一.概述 工厂,就是生产产品的地方. 在Java设计模式中使用工厂的概念,那就是生成对象的地方了. 本来直接就能创建的对象 ...

  3. java设计模式(二)---工厂方法模式

    2普通工厂方法模式 就是建立一个工厂类,对实现了同一接口的一些类进行实例的创建. 2.1创建接口 /** * 发送接口 * Created by mrf on 2016/2/25. */ public ...

  4. JAVA设计模式之工厂方法模式

    在阎宏博士的<JAVA与模式>一书中开头是这样描述工厂方法模式的: 工厂方法模式是类的创建模式,又叫做虚拟构造子(Virtual Constructor)模式或者多态性工厂(Polymor ...

  5. Java 设计模式(四)-工厂方法模式 (FactoryMethod Pattern)

    1     概念定义 1.1   定义 定义一个用于创建对象的接口,让子类决定实例化哪一个类.工厂方法使一个类的实例化延迟到其子类. 1.2   类型 创建类模式 2     原理特征 2.1   类 ...

  6. 【java】 java 设计模式(1):工厂方法模式(Factory Method)

    工厂方法模式分为三种: 1.普通工厂模式,就是建立一个工厂类,对实现了同一接口的一些类进行实例的创建.首先看下关系图: 举例如下:(我们举一个发送邮件和短信的例子) 首先,创建二者的共同接口:   p ...

  7. java设计模式学习 ----- 工厂方法模式(Factory Method)

    工厂方法模式(Factory Method) 工厂方法模式分为三种:普通工厂模式.多个工厂方法模式.静态工厂方法模式 普通工厂模式,就是建立一个工厂类,对实现了同一接口的一些类进行实例的创建. 关系图 ...

  8. Java设计模式(2)——工厂方法模式

    工厂方法模式同样属于类的创建型模式又被称为多态工厂模式.工厂方法模式的意义是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类当中.核心工厂类不再负责产品的创建,这样核心类成为一个抽象工厂角色, ...

  9. C#设计模式(3)——工厂方法模式

    一.概念:定义一个用于创建对象的接口,让子类决定实例化哪一个类,工厂方法使一个类的实例化延迟到其子类. 二.代码实现 namespace 设计模式之工厂方法模式 { /// <summary&g ...

随机推荐

  1. SimpleDateFormat 12小时制以及24小时制的写法

    有些代码按了复制键没有效果,但是其实已经复制到剪贴板上面了,大家请注意哦! 我的文章有时会稍有修改,转载请注明出处哦! 原文地址:SimpleDateFormat 12小时制以及24小时制的写法 去代 ...

  2. C#中操作XML文件

    1.添加结点:XmlNode xmldoc.Load("..\\..\\App.config"); //根元素 XmlElement root = xmldoc.DocumentE ...

  3. LyX-220-Installer-3

    所见即所得 单独安装这个写作业可以了,要发论文用CTeX Ctrl + M 打开数学输入,里面可以输入 TeX 代码

  4. css 常用代码解析

    .cBan_1 .e2-pro li a{ display: block; -webkit-transition: all 0.3s linear;transition: all 0.3s linea ...

  5. yum提示字符编码错误

    1.问题描述: [root@localhost data]# yum Loaded plugins: product-id, refresh-packagekit, security, subscri ...

  6. VM EXSI安装使用

    1.下载VM ESXI:http://lookdfw.blog.163.com/blog/static/5824974220139295524473/ 2.安装VM ESXI: 参考网址:http:/ ...

  7. autofac Adding services after container has been built

    http://stackoverflow.com/questions/6173566/run-time-registration-with-autofac Yes you can, using the ...

  8. js的元素对象

    元素对象(element对象)        ** 要操作element对象,首先必须要获取到element,                       - 使用document里面相应的方法获取  ...

  9. 开源项目管理平台*redmine*的架设

    yum -y install ruby yum install rubygems gem install heroku gem install rack -v=1.0.1 gem install ru ...

  10. 新浪微博客户端(63)-使用block进行链式编程

    Person.h #import <Foundation/Foundation.h> @interface Person : NSObject - (Person *(^)())study ...