一:简单工厂:

有一个实际工厂,这个工厂只能造一类的产品,这一类产品就是一个产品接口,会有多个具体产品实现这个接口,例 如,一个手机厂,生产苹果手机,三星手机;

缺点:在工厂类中集中了所有实例的创建逻辑,违反了高内聚责任分配原则,将全部创建逻辑集中到了一个工厂类中;对系统的维护和扩展不利;

使用场景:负责创建的对象比较少;客户只知道传入工厂类的参数,对于如何创建对象的逻辑不关心;容易违反高内聚责任分配原则,所以只在很简单的情况下应用;

package com.designPattern.simpleFactory;

public interface Shape {   // 产品接口

public String toString();

}

package com.designPattern.simpleFactory;

public class ShapeA implements Shape {  // 具体产品

@Override
public String toString()
{
return "shape A";
}
}

package com.designPattern.simpleFactory;

public class ShapeB implements Shape {  // 具体产品
@Override
public String toString()
{
return "shape B";
}
}

package com.designPattern.simpleFactory;

public class ShapeFactory {

public static Shape createShape(String shapeStr)
{
switch(shapeStr)
{
case "ShapeA": return new ShapeA();
case "ShapeB": return new ShapeB();
}
return null;
}

public static void main(String[] args)
{
Shape A = ShapeFactory.createShape("ShapeA");
Shape B = ShapeFactory.createShape("ShapeB");

System.out.println(A);
System.out.println(B);
}
}

二:工厂方法:

比简单工厂高级一点了,一个工厂的接口,多个工厂实现这个工厂接口,一个产品接口,多个具体产品实现这个产品接口,例如,一个手机厂接口,有苹果手机厂,三星手机厂两个具体工厂,苹果手机厂生产苹果手机,三星手机厂生产三星手机;可以在不修改具体工厂角色的情况下引用新的产品,一个抽象工厂对应一个抽象产品,一个具体工厂对应一个具体产品。

使用场景:对于某个产品,调用者清楚知道应该使用哪个具体工厂服务,实例化该具体工厂,生产出具体的产品来;   

package com.designPattern.factoryMethod;

public interface Car {    // 产品接口
void gotowork();
}

package com.designPattern.factoryMethod;

public interface ICarFactory {  // 生产产品的类厂接口

Car getCar();
}

package com.designPattern.factoryMethod;

public class Bike implements Car {  //  具体产品
@Override
public void gotowork() {
// TODO Auto-generated method stub
}
}

package com.designPattern.factoryMethod;
public class Bus implements Car {  // 具体产品
@Override
public void gotowork() {
}
}

package com.designPattern.factoryMethod;

public class BikeFactory implements ICarFactory {  // 具体产品工厂

@Override
public Car getCar() {
// TODO Auto-generated method stub
return null;
}
}

package com.designPattern.factoryMethod;

public class BusFactory implements ICarFactory {  // 具体产品工厂
@Override
public Car getCar() {
return null;
}
}

package com.designPattern.factoryMethod;
public class TestFactory {
public static void main(String[] args)
{
ICarFactory factory = null;

factory = new BikeFactory();
Car bike = factory.getCar();
bike.gotowork();

factory = new BusFactory();
Car bus = factory.getCar();
bus.gotowork();
}
}

三:抽象工厂:

前两种工厂,说到底都只能生产一类产品(都是手机),抽象工厂支持多种类型的产品。一个工厂接口,多个 具体工厂,多个产品接口,多个具体产品,例如,电器厂接口,有三星厂和苹果厂两个具体工厂,三星厂生产三星手机,  三星电脑,苹果厂生产苹果手机,苹果电脑。户端在不必指定产品的具体情况下,创建多个产品族中的产品对象。

package com.designPattern.abstractFactory;

public interface AbstractFactory {  // 抽象工厂
public ProductA factoryA();
public ProductB factoryB();
}

package com.designPattern.abstractFactory;

public class ConcreateFacotry1 implements AbstractFactory {   //具体工厂

@Override
public ProductA factoryA() {

return new ConcreateProductA1();
}

@Override
public ProductB factoryB() {
return new ConcreateProductB1();
}

}

package com.designPattern.abstractFactory;

public class ConcreateFactory2 implements AbstractFactory {  //具体工厂

@Override
public ProductA factoryA() {
return new ConcreateProductA2();
}

@Override
public ProductB factoryB() {
// TODO Auto-generated method stub
return new ConcreateProductB2();
}
}

package com.designPattern.abstractFactory;

public interface ProductA {   // 抽象产品
public void method1();
public void method2();

}

package com.designPattern.abstractFactory;

public interface ProductB {  // // 抽象产品
public void method1();
public void method2();
}

package com.designPattern.abstractFactory;

public class ConcreateProductA1 implements ProductA {     // 具体产品

@Override
public void method1() {
System.out.println("等级为1的A的method1");

}

@Override
public void method2() {
System.out.println("等级为1的A的method2");
}
}

package com.designPattern.abstractFactory;

public class ConcreateProductA2 implements ProductA {   // 具体产品

@Override
public void method1() {
System.out.println("等级为2的A的method1");
}

@Override
public void method2() {
System.out.println("等级为2的A的method2");
}

}

package com.designPattern.abstractFactory;

public class ConcreateProductB1 implements ProductB {  // 具体产品

@Override
public void method1() {
System.out.println("等级为1的B的method1");
}

@Override
public void method2() {
System.out.println("等级为1的B的method2");
}

}

package com.designPattern.abstractFactory;

public class ConcreateProductB2 implements ProductB {  // 具体产品

@Override
public void method1() {
System.out.println("等级为2的产品B的method1()");
}

@Override
public void method2() {
System.out.println("等级为2的产品B的method2()");
}

}

package com.designPattern.abstractFactory;

public class test {

public static void main(String[] args) {

AbstractFactory ff = new ConcreateFacotry1();

ProductA aa = ff.factoryA();
ProductB bb = ff.factoryB();

aa.method1();
aa.method2();

bb.method1();
bb.method2();

AbstractFactory f2 = new ConcreateFactory2();
aa = f2.factoryA();
bb = f2.factoryB();

aa.method1();
aa.method2();

bb.method1();
bb.method2();
}
}

设计模式—三种工厂模式(JAVA)的更多相关文章

  1. java设计模式---三种工厂模式之间的区别

    简单工厂,工厂方法,抽象工厂都属于设计模式中的创建型模式.其主要功能都是帮助我们把对象的实例化部分抽取了出来,优化了系统的架构,并且增强了系统的扩展性. 本文是本人对这三种模式学习后的一个小结以及对他 ...

  2. java设计模式三种工厂模式简单介绍

    一.简单工厂模式 概述:简单工厂模式的创建意图就是,把对类的创建初始化全都交给一个工厂来执行,而用户不需要去关心创建的过程是什么样的,只用告诉工厂我想要什么就行了.而这种方法的缺点也很明显,违背了设计 ...

  3. java设计模式---三种工厂模式

    工厂模式提供创建对象的接口. 工厂模式分为三类:简单工厂模式(Simple Factory), 工厂方法模式(Factory Method)和抽象工厂模式(Abstract Factory).GOF在 ...

  4. 三种工厂模式的分析以及C++实现

    三种工厂模式的分析以及C++实现 以下是我自己学习设计模式的思考总结. 简单工厂模式 简单工厂模式是工厂模式中最简单的一种,他可以用比较简单的方式隐藏创建对象的细节,一般只需要告诉工厂类所需要的类型, ...

  5. java三种工厂模式

    适用场合: 7.3 工厂模式的适用场合 创建新对象最简单的办法是使用new关键字和具体类.只有在某些场合下,创建和维护对象工厂所带来的额外复杂性才是物有所值.本节概括了这些场合. 7.3.1 动态实现 ...

  6. java 三种工厂模式

    一.简单工厂模式 一个栗子: 我喜欢吃面条,抽象一个面条基类,(接口也可以),这是产品的抽象类. public abstract class INoodles { /** * 描述每种面条啥样的 */ ...

  7. 深入理解Java的三种工厂模式

    一.简单工厂模式 简单工厂的定义:提供一个创建对象实例的功能,而无须关心其具体实现.被创建实例的类型可以是接口.抽象类,也可以是具体的类 实现汽车接口 public interface Car { S ...

  8. Java的三种工厂模式

    一.简单工厂模式 简单工厂的定义:提供一个创建对象实例的功能,而无须关心其具体实现.被创建实例的类型可以是接口.抽象类,也可以是具体的类 实现汽车接口 //产品接口 //汽车需要满足一定的标准 pub ...

  9. Java设计模式之三种工厂模式

    工厂模式实现了创建者和调用者的分离,实现了更好的解耦.   详细分类: 1) 简单工厂模式(静态工厂模式): 2) 工厂方法模式: 3) 抽象工厂模式 面向对象设计的基本原则: 1)       OC ...

随机推荐

  1. PriorityBlockingQueue用法

    摘自<Java编程思想> package com.test.concurrency; import java.util.ArrayList; import java.util.List; ...

  2. APUE学习笔记——10 信号

    信号的基本概念     信号是软件中断,信号提供了解决异步时间的方法.     每一中信号都有一个名字,信号名以SIG开头. 产生信号的几种方式     很多条件可以产生信号:     终端交互:用户 ...

  3. Python面向对象 --- 类的设计和常见的内置方法

    面向对象:一种基于面向过程的新的编程思想.也就是说面向对象是将功能等通过对象来实现,将功能封装进对象之中,让对象去实现具体的细节:这种思想是将数据作为第一位,而方法或者说是算法作为其次,这是对数据一种 ...

  4. PostgreSQL时间格式及相关函数实践

    在创建表的时候,有客户需要将时间转为字符串,而且要求了具体的格式,如:20181115101010001.方便记录数据的更新时间,貌似是给Mysql使用,当时就很蛋疼,时间格式存储子啊数据库中就是va ...

  5. CUDA Samples: Dot Product

    以下CUDA sample是分别用C++和CUDA实现的两个非常大的向量实现点积操作,并对其中使用到的CUDA函数进行了解说,各个文件内容如下: common.hpp: #ifndef FBC_CUD ...

  6. gdi+ 中发生一般性错误 wpf解决方法

    错误背景:原来在winform程序中写了一个窗口,在wpf应用程序中调用显示了这个窗口,有个头像功能,加载本地的一个图片文件,加载前进行了各种逻辑判断,效果如下: 而加载的关键代码如下面: pictu ...

  7. VS2010对c++11的支持情况验证

    目前仅仅测试工作中 使用的比较多的: 智能指针 shared_ptr #include <memory> std::shared_ptr<A> a(new A); ----支持 ...

  8. JSP学习(二)JSP指令

    JSP指令 JSP指令(directive)是为JSP引擎而设计的,它们并不直接产生任何可见输出,而只是告诉引擎如何处理JSP页面中的其余部分. JSP指令的基本语法格式:<%@ 指令 属性名= ...

  9. PageViewController和UIPageControl

    以前经常把这两个东西当成一回事, PageViewController像电子书那样,一页之中可以放几个childViewcontroller,  然后左右翻,当前frame显示几个viewcontro ...

  10. ubuntu qq安装

    安装最新版qq2016 qq2012下载链接: https://pan.baidu.com/s/1miFVc04 密码: 3g9w 先解压到自己所在的目录,解压命令自己百度在这个目录下,有三个解压包, ...