创建型设计模式总结(二)

上篇文章我们介绍了创建型设计模式的前三种:简单工厂模式、工厂方法模式和抽象工厂模式。这一篇文章,我们系统介绍一下其他的三种创建型设计模式:创建者模式、原型模式和单例模式。

一.创建者模式

创建者模式又叫建造者模式,是将一个复杂的对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。创建者模式隐藏了复杂对象的创建过程,它把复杂对象的创建过程加以抽象,通过子类继承或者重载的方式,动态的创建具有复合属性的对象。

创建者模式通常包括如下几种角色:

1.建造者角色(Builder)

对复杂对象的创建过程加以抽象,给出一个抽象接口,以规范产品对象的各个组成部分的建造。这个接口规定了要实现复杂对象的哪个部分的创建,但并不涉及具体对象不见的创建。

2.具体创建者角色(ConcreateBuilder)

实现Builder接口,针对不同的业务逻辑,具体化复杂对象的各个部分的创建。在建造过程完成后,提供产品的实例。

3.指导者(Director)

调用具体建造者来创建复杂对象的各个部分,在指导者中不设计具体产品的信息,只负责保证对象各部分完整创建或者按某种顺序创建。

4.产品(Product)

要创建的复杂对象,一般来说包含多个部分。

下面给出创建者模式的UML图:

下面我们通过代码体会一下:

首先我们定义Product类,里面用一个List存储product对象的各个部分:

 1 /**
 2  * Created by ufenqi lixiuyu.
 3  */
 4 public class Product {
 5     private List<String> parts = new ArrayList<String>();
 6
 7     public void add(String partName){
 8         parts.add(partName);
 9     }
10
11     public void show(){
12         System.out.println("----产品创建----");
13         for (String part : parts) {
14             System.out.println(part);
15         }
16     }
17 }

然后,我们定义Builder抽象类,并定义Product包括partA,partB,partC三个部分:

1 public abstract class Builder {
2     protected abstract void buildPartA();
3     protected abstract void buildPartB();
4     protected abstract void buildPartC();
5
6     protected abstract Product getResult();
7 }

下面分别定义ConcreateBuilder角色的BuilderA及BuilderB:

 1 public class BuilderA extends Builder {
 2     private Product product = new Product();
 3
 4     @Override
 5     protected void buildPartA() {
 6         product.add("partA");
 7     }
 8
 9     @Override
10     protected void buildPartB() {
11         product.add("partB");
12     }
13
14     @Override
15     protected void buildPartC() {
16         product.add("partC");
17     }
18
19     @Override
20     protected Product getResult() {
21         return product;
22     }
23 }
 1 public class BuilderB extends Builder {
 2     private Product product = new Product();
 3
 4     @Override
 5     protected void buildPartA() {
 6         product.add("partX");
 7     }
 8
 9     @Override
10     protected void buildPartB() {
11         product.add("partY");
12     }
13
14     @Override
15     protected void buildPartC() {
16         product.add("partZ");
17     }
18
19     @Override
20     protected Product getResult() {
21         return product;
22     }
23 }

下面我们定义指导者角色BuilderDirector,在类中添加Builder的引用,并通过其构造方法初始化builder属性:

 1 public class BuilderDirector {
 2
 3     private Builder builder = null;
 4
 5     public BuilderDirector(Builder builder){
 6         this.builder = builder;
 7     }
 8
 9     public Product build(){
10         builder.buildPartA();
11         builder.buildPartB();
12         builder.buildPartC();
13         return builder.getResult();
14     }
15
16 }

编写测试类:

 1 public class BuilderTest {
 2
 3     public static void main(String[] args) {
 4
 5         BuilderDirector director = new BuilderDirector(new BuilderB());
 6         Product product = director.build();
 7         product.show();
 8     }
 9
10 }

运行结果如下:

----产品创建----
partX
partY
partZ

总结:

1)使用建造者模式的好处:

①使用建造者模式可以使客户端不必知道产品内部组成的细节。

②具体的建造者类之间是相互独立的,这有利于系统的扩展。

③具体的建造者相互独立,因此可以对建造的过程逐步细化,而不会对其他模块产生任何影响。

2)建造者模式的使用场景:

①创建一些复杂对象时,这些对象的内部组成部分之间的建造顺序是稳定的,但对象的内部组成构建面临着复杂的变化。

②要创建的复杂对象的算法,独立于该对象的组成部分,也独立于组成部分的装配方法时。

二.原型模式

该模式的思想就是将一个对象作为原型,对其进行复制、克隆,产生一个和原对象类似的新对象。

而这里的复制有两种:浅复制、深复制。

浅复制:将一个对象复制后,基本数据类型的变量都会重新创建,而引用类型,指向的还是原对象所指向的。

深复制:将一个对象复制后,不论是基本数据类型还有引用类型,都是重新创建的。简单来说,就是深复制进行了完全彻底的复制,而浅复制不彻底。

三.单例模式

时间: 2024-12-19 12:19:54

创建型设计模式总结(二)的相关文章

创建型设计模式(二)抽象工厂模式

一.一句话背景 假如我是一个汽车经销商,那我不光是卖车,也得卖相关的配件吧,比如润滑油,轮胎之类的,那我能不能整一个抽象的工厂,我需要啥直接告诉这个抽象工厂,具体生产哪一类产品让这个抽象工厂自己去对接,这样我不管需要啥都只用找这个抽象工厂的负责人就可以,而不用找每一类具体产品工厂的负责人,我可就省事多了~ 二.使用场景 调用一整套产品族的场景. 如:参加不同类型的抽奖活动,QQ换皮肤 三.模型分析 生产流水线:接口,定义生产具体产品的方法 具体产品的生产流水线:类,定义生产具体特征(颜色,品牌等

六种创建型设计模式的比较和总结

一.描述 创建型设计模式包括如下几个:简单工厂模式(Simple Factory).工厂方法模式(Factory Method).抽象工厂模式(Abstract Factory).创建者模式(Builder).原型模式(Prototype).单例模式(Singleton). 二.六种创建型设计模式的比较 简单工厂模式:简单工厂模式又叫静态工厂模式,它定义一个具体的工厂类来负责所有产品对象的创建,因此这个工厂类的职责过大,当客户端UI与某些产品的创建有不同的要求时,需要不断地修改工厂类,增加判断逻

[Python编程实战] 第一章 python的创建型设计模式1.1抽象工厂模式

注:关乎对象的创建方式的设计模式就是"创建型设计模式"(creational design pattern) 1.1 抽象工厂模式 "抽象工厂模式"(Abstract Factory Pattern)用来创建复杂的对象,这种对象由许多小对象组成,而这些小对象都属于某个特定的"系列"(family). 比如说,在GUI 系统里可以设计"抽象控件工厂"(abstract widget factory),并设计三个"具体子

设计模式之:创建型设计模式(6种)

创建型设计模式有: 共6种 简单工厂模式(Simple Factory) 工厂方法模式(Factory Method) 抽象工厂模式(Abstract Factory) 建造者模式(Builder) 原型模式(Prototype) 单例模式(Singleton) 简单工厂模式 功能:主要用于创建对象.新添加类时,不会影响以前的系统代码.核心思想是用一个工厂来根据输入的条件产生不同的类,然后根据不同类的virtual函数得到不同的结果. 优点: 适用于不同情况创建不同的类时 缺点: 客户端必须要知

外观模式 门面模式 Facade 创建型 设计模式(十三)

外观模式(FACADE) 又称为门面模式 意图 为子系统中的一组接口提供一个一致的界面 Facade模式定义了一个高层接口,这一接口使得这一子系统更加易于使用. 意图解析 随着项目的持续发展,系统基本上都是会往功能更全面的方向发展,那么也就意味着我们的系统将会变得更加复杂. 系统会被划分为多个单独的子系统,每个子系统完成一部分功能,通过分工协作完成全部功能. 一个子系统也可能进一步拆分为更小的几个子系统. 程序中的文件将会越来越多,相互关联也会变得更加复杂 当使用一个功能的时候,作为客户端 你需

访问者模式 Visitor 行为型 设计模式(二十七)

访问者模式 Visitor <侠客行>是当代作家金庸创作的长篇武侠小说,新版电视剧<侠客行>中,开篇有一段独白: “茫茫海外,传说有座侠客岛,岛上赏善罚恶二使,每隔十年必到中原武林,向各大门派下发放赏善罚恶令, 强邀掌门人赴岛喝腊八粥,拒接令者,皆造屠戮,无一幸免,接令而去者,杳无音讯,生死未仆,侠客岛之行,已被视为死亡之旅.” 不过话说电视剧,我总是觉得老版的好看. 意图 表示一个作用于某对象结构中的各元素的操作. 它使你可以在不改变各元素类的前提下定义作用于这些元素的新操作.

创建型设计模式总结

创建型设计模式共有五种:单例模式,简单工厂模式,抽象工厂模式,建造者模式,原型模式. 单例模式:创建一个只能new一次的类,只要这个类的资源没有被释放,无法在被实例化.确保对象的唯一性. 简单工厂模式:一个抽象实现类,一个抽象工厂类,分别需要普通类继承于这两个类,使用的时候实例化抽象工厂类指定到实现类,调用工厂方法.在有新需求时只需要添加一个具体产品类和对应的实现工厂,无需对原工厂进行任何修改.不过这样在一定时间积累之后会让自己的代码过于沉重和复杂,当程序已经满足不了原有的需求时,改起来会很困难

一、创建型设计模式

包括简单工厂.工厂方法.抽象工厂.建造者.原型和单例模式. 1)简单工厂 又叫静态工厂方法,由一个工厂对象决定创建某一种产品对象类的实例. 两种实现方式,第一种是通过类实例化对象创建,第二种是创建一个新对象然后包装增强其属性和功能. demo代码. 2)工厂方法 通过对产品类的抽象使其创建业务主要负责用于创建多类产品的实例. 将工厂方法看作是一个实例化对象的工厂类. demo代码. 3)抽象工厂 通过对类的工厂抽象使其业务用于对产品类簇的创建,而不负责创建某一类产品的实例. 用它作为父类来创建一

创建型设计模式 之 原型模式

同为创建型模式的原型模式与单例模式是密不可分的,这也是最常用的设计模式之一. 原型模式是一种非常简单的设计模式.这里除了基本介绍和演示,还详细介绍了Java中原型模式的本质. 一.介绍 同样,先来看一下<研磨设计模式>的定义——用原型实例指定创建对象的种类,并通过拷贝这些原型创建新的对象. 原型模式的本质——克隆生成对象. 那么原型模式是什么意思呢?说白了就是克隆自身.我们知道Java中没有引用这个概念,Java用变量名代表引用.像 Apple a = new Apple();我们知道,想要操