【HeadFirst 设计模式学习笔记】18 原型(Prototype)模式拾零

简介: 作者:gnuhpc 出处:http://www.cnblogs.com/gnuhpc/ 1.概述 这个模式在Head First这本书中也没有具体提到。其主要应用于如下场景:对于创建一个新的对象,若且你手中已经有了一个非常相像的对象实例,那么你可以利用这个现有对象进行新对象的创建。

作者:gnuhpc
出处:http://www.cnblogs.com/gnuhpc/

1.概述

这个模式在Head First这本书中也没有具体提到。其主要应用于如下场景:对于创建一个新的对象,若且你手中已经有了一个非常相像的对象实例,那么你可以利用这个现有对象进行新对象的创建。用现实中的例子来说,比如细胞分裂,一个细胞分裂为两个细胞(可能这个比喻在生物学上有些出入)。参与这个模式的两种实体为:

原型:一个提供克隆自己的接口的抽象。

具体原型:实现这个克隆自己的的接口的具体实现类。

2.实例

首先我们实现一个原型模式的原始例子,这里利用了Java中Object的clone()方法:

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

显然上边的这个例子并没有多少实用性,下边的例子中我们要创建一个具有克隆自己功能的表示相关产品的对象,实现上利用了简单工厂方法——这个经常和原型模式一起使用。

我们利用Java中的Cloneable接口定义原型,其中就提供了一个克隆自己的方法的接口定义。然后我们实现这个具体原型,当然相对于标准的原型模式,这里面有增加了一层产品的抽象,因为毕竟Java中的Cloneable是一个接口,需要有一层实现这个接口中clone方法的抽象作为抽象产品类。

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

然后我们根据这个抽象类创建两个具体的原型类,如果用简单工厂方法的视角那就是一个具体产品类,不过这并不要紧:

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

现在我们创建一个工厂(为了演示多个具体产品类,这个工厂定义的比较特殊——生产书和衣服)来创建这些产品:

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

这个工厂的特殊之处是需要复制的对象已经创立好了,在创建工厂实例的时候通过loadCache就可以完成。

下边我们使用这个工厂克隆生产一本书和一件衣服:

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
3.UML总结 

Prototype_2

这里没有画简单工厂模式的实体。

原型模式多用于创建复杂的或者耗时的实例,因为这种情况下,复制一个已经存在的实例使程序运行更高效;或者创建值相等,只是命名不一样的同类数据(克隆以后进行定制)。

 

作者:gnuhpc
出处:http://www.cnblogs.com/gnuhpc/


               作者:gnuhpc
               出处:http://www.cnblogs.com/gnuhpc/
               除非另有声明,本网站采用知识共享“署名 2.5 中国大陆”许可协议授权。


分享到:

目录
相关文章
|
10天前
|
设计模式 SQL 算法
设计模式了解哪些,模版模式
设计模式了解哪些,模版模式
19 0
|
29天前
|
设计模式 Java uml
C++设计模式之 依赖注入模式探索
C++设计模式之 依赖注入模式探索
37 0
|
6天前
|
设计模式 Java 数据库
小谈设计模式(2)—简单工厂模式
小谈设计模式(2)—简单工厂模式
|
6天前
|
设计模式 Java
小谈设计模式(9)—工厂方法模式
小谈设计模式(9)—工厂方法模式
|
1月前
|
设计模式 编译器
解析器模式--设计模式
解析器模式--设计模式
17 0
|
1月前
|
设计模式 算法
构建器模式--设计模式
构建器模式--设计模式
17 0
|
1月前
|
设计模式
【设计模式】中介模式
【设计模式】中介模式
|
3月前
|
设计模式 存储 算法
Java 设计模式最佳实践:三、行为模式
Java 设计模式最佳实践:三、行为模式
|
3月前
|
设计模式 Go 开发工具
Golang设计模式——12中介模式
Golang设计模式——12中介模式
25 0
|
2月前
|
设计模式 前端开发 JavaScript
观察者模式 vs 发布-订阅模式:两种设计模式的对决!
欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚开始学习前端的读者们打造的。无论你是初学者还是有一些基础的开发者,我们都会在这里为你提供一个系统而又亲切的学习平台。我们以问答形式更新,为大家呈现精选的前端知识点和最佳实践。通过深入浅出的解释概念,并提供实际案例和练习,让你逐步建立起一个扎实的基础。无论是HTML、CSS、JavaScript还是最新的前端框架和工具,我们都将为你提供丰富的内容和实用技巧,帮助你更好地理解并运用前端开发中的各种技术。