【秒懂设计模式】原型模式

 秒懂设计模式——原型模式


(五)原型模式

【官方定义】用原型实例指定创建对象的种类,并且通过拷贝这些原型,创建新的对象,属于对象创建模式。

【举例】在找工作的时候,通常需要我们的毕业证和学位证,但是我们一般不会把原件(原型实例)给到用人单位,而是会把原件复印(拷贝)几份,然后供用人单位使用。

【Java代码】

①创建一个证书抽象类。

package com.liyan.prototype;
/**
 * 证书抽象类
 * <p>Title: Certificate</p>
 * @author  Liyan
 * @date    2017年5月2日 下午3:17:37
 */
public abstract class Certificate implements Cloneable{

	/**证书编号*/
	private Integer id;

	/**证书名称*/
	protected String name;

	/**测试方法*/
	abstract void testMethod();

	public Integer getId() {
		return id;
	}

	public void setId(Integer id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	@Override
	protected Object clone() throws CloneNotSupportedException {
		return super.clone();
	}

	@Override
	public String toString() {
		return "Certificate [id=" + id + ", name=" + name + "]";
	}

}

②创建证书扩展类——毕业证

package com.liyan.prototype;
/**
 * 数据信息扩展类——毕业证
 * <p>Title: GraduationCertificate</p>
 * @author  Liyan
 * @date    2017年5月2日 下午3:17:47
 */
public class GraduationCertificate extends Certificate{

	public GraduationCertificate() {
		name = "毕业证";
	}

	@Override
	void testMethod() {
		System.out.println("毕业证复印完成!");
	}

}

③创建证书扩展类——学位证

package com.liyan.prototype;
/**
 * 证书扩展类——学位证
 * <p>Title: DegreeCertificate</p>
 * @author  Liyan
 * @date    2017年5月2日 下午3:18:26
 */
public class DegreeCertificate extends Certificate{

	public DegreeCertificate() {
		name = "学位证";
	}

	@Override
	void testMethod() {
		System.out.println("学位证复印完成!");
	}

}

④创建原型模式管理器——证书管理器

package com.liyan.prototype;
import java.util.HashMap;

/**
 * 原型模式管理器——证书管理器
 * <p>Title: CertificateManger</p>
 * @author  Liyan
 * @date    2017年5月2日 下午3:24:40
 */
public class CertificateManger {
	//证书的map集合
	private static HashMap<Integer, Certificate> certificateMap = new HashMap<Integer, Certificate>(0);
	//私有构造方法
	private CertificateManger (){}
	//懒加载构建原型模式管理器的单例模式
	private static CertificateManger certificateManger = null;

	/**
	 * 获取单例模式的原型模式管理器
	 * <p>Title: getCertificateManger</p>
	 * @author Liyan
	 * @date   2017年5月2日 下午3:24:51
	 * @return CertificateManger
	 */
	public static CertificateManger getCertificateManger() {
		if (certificateManger == null) {
			certificateManger = new CertificateManger();
		}
		return certificateManger;
	}

	/**
	 * 加载缓存
	 * <p>Title: getLoad</p>
	 * @author Liyan
	 * @date   2017年5月2日 下午3:25:07
	 */
	public static void getLoad() {
		GraduationCertificate certificate1 = new GraduationCertificate();
		certificateMap.put(1, certificate1);
		DegreeCertificate certificate2 = new DegreeCertificate();
		certificateMap.put(2, certificate2);
	}  

	/**
	 * 根据key获取克隆后的对象
	 * <p>Title: getCertificate</p>
	 * @author Liyan
	 * @date   2017年5月2日 下午3:25:31
	 * @param key
	 * @return Certificate
	 */
	public static Certificate getCertificate(Integer key) {
		try {
			Certificate certificate = (Certificate) certificateMap.get(key);
			if (certificate != null) {
				Certificate datinfo = (Certificate) certificate.clone();
				System.out.println("key="+key+"的对象克隆完成,datinfo="+datinfo);
				return datinfo;
			}else {
				System.out.println("key="+key+"并未加载!");
				return null;
			}
		} catch (CloneNotSupportedException e) {
			e.printStackTrace();
		}
		return null;
	}

}

⑤测试

package com.liyan.prototype;
/**
 * 测试
 * <p>Title: Test</p>
 * @author  Liyan
 * @date    2017年5月2日 下午3:30:21
 */
public class Test {
	@SuppressWarnings("static-access")
	public static void main(String[] args) {
		//提前加载到缓存数据
		CertificateManger.getLoad();
		//获取单例类CertificateManger
		CertificateManger manger  = CertificateManger.getCertificateManger();
		//获取毕业证复印件
		Certificate certificate1 = manger.getCertificate(1);
		certificate1.testMethod();
		//获取学位证复印件
		Certificate certificate2 = manger.getCertificate(2);
		certificate2.testMethod();
	}
}

⑥测试结果

key=1的对象克隆完成,datinfo=Certificate [id=null, name=毕业证]
毕业证复印完成!
key=2的对象克隆完成,datinfo=Certificate [id=null, name=学位证]
学位证复印完成!

图解关系:

 

分析:

这种模式是实现了一个原型接口,该接口用于创建当前对象的克隆。当直接创建对象的代价比较大时,则采用这种模式。

独特的优点

(1)性能比直接new一个对象要好的多。因为clone方法是一个本地方法,它直接操作内存中的二进制流,特别是复制大对象时,性能的差别非常明显,所以在需要重复地创建相似对象时可以考虑使用原型模式。

(2)原型模式创建模式不会损坏原有对象

(3)工厂模式对新产品的适应能力比较弱,层级结构比较复杂,没有原型模式简洁

注意事项:

(1)使用原型模式复制对象不会调用类的构造方法。因为clone方法,会直接在内存中复制数据。

(2)单例模式与原型模式是冲突的。因为clone方法直接无视构造方法的权限。

时间: 2024-08-17 14:44:02

【秒懂设计模式】原型模式的相关文章

设计模式-原型模式

设计模式-原型模式 效果: 原型模式,其实就是完整的复制一个对象,以一个对象为样本,进行复制作业,然后再来使用. 以下以复制一个UIView的操作来讲解原型模式的实现 注:UIView对象是不能够复制的,我们需要完整的把UIView对象的参数都复制了后,就行了. http://stackoverflow.com/questions/4425939/can-uiview-be-copied Your app probably crashes with something like: [UIView

4、Python与设计模式--原型模式

一.图层 大家如果用过类似于Photoshop的平面设计软件,一定都知道图层的概念.图层概念的提出,使得设计.图形修改等操作更加便利.设计师既可以修改和绘制当前图像对象,又可以保留其它图像对象,逻辑清晰,且可以及时得到反馈.本节内容,将以图层为主角,介绍原型模式. 首先,设计一个图层对象. class simpleLayer: background=[0,0,0,0] content="blank" def getContent(self): return self.content d

PHP设计模式——原型模式

     声明:本系列博客参考资料<大话设计模式>,作者程杰.        用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象.Prototype模式允许一个对象再创建另外一个可定制的对象,根本无需知道任何如何创建的细节,通过将一个原型对象传给那个要发动创建的对象,这个要发动创建的对象通过请求原型对象拷贝它们自己来实施创建.它主要面对的问题是:"某些结构复杂的对象"的创建工作:由于需求的变化,这些对象经常面临着剧烈的变化,但是他们却拥有比较稳定一致的接口.  

.NET设计模式-原型模式(Prototype Pattern)

原型模式(Prototype Pattern) --.NET设计模式系列之六 Terrylee,2006年1月 概述 在软件系统中,有时候面临的产品类是动态变化的,而且这个产品类具有一定的等级结构.这时如果用工厂模式,则与产品类等级结构平行的工厂方法类也要随着这种变化而变化,显然不大合适.那么如何封装这种动态的变化?从而使依赖于这些易变对象的客户程序不随着产品类变化? 意图 用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象. 结构图 Prototype模式结构图 生活中的例子 Pr

Java设计模式--原型模式

原型模式 用原型实例制定创建对象的种类,并且通过复制这些原型创建新的对象. Prototype Pattern Specify the kinds of objects to create using a prototypical instance, and create new objects by copying this prototype. 类图 模式的结构与使用 原型方法模式的结构中包括两种角色. + 抽象原型(Abstract Prototype):是一个接口,负责定义对象复制自身的

设计模式之禅之设计模式-原型模式

一:原型模式的定义        --->用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象        --->原型模式(Prototype Pattern)的简单程度仅次于单例模式和迭代器模式.正是由于简单,使用的场景才非常地多        --->原型模式的核心是一个clone方法,通过该方法进行对象的拷贝,Java提供了一个Cloneable接口来标示这个对象是可拷贝的,为什么说是"标示"呢?翻开JDK的帮助看看Cloneable是一个方法都没

实例讲解C++编程中对设计模式中的原型模式的使用_C 语言

原型模式的实现完整代码示例(code):原型模式的实现很简单,这里为了方便初学者的学习和参考,将给出完整的实现代码(所有代码采用 C++实现,并在 VC 6.0 下测试运行). 代码片断 1:Prototype.h //Prototype.h #ifndef _PROTOTYPE_H_ #define _PROTOTYPE_H_ class Prototype{ public: virtual ~Prototype(); virtual Prototype* Clone() const = 0;

解析设计模式中的Prototype原型模式及在C++中的使用_C 语言

原型模式的意图是用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象. 适用性 当要实例化的类是在运行时刻指定时,例如,通过动态装载:或者 为了避免创建一个与产品类层次平行的工厂类层次时:或者 当一个类的实例只能有几个不同状态组合中的一种时.建立相应数目的原型并克隆它们可能比每次用合适的状态手工实例化该类更方便一些. 关于这个模式,突然想到了小时候看的<西游记>,齐天大圣孙悟空再发飙的时候可以通过自己头上的 3 根毛立马复制出来成千上万的孙悟空,对付小妖怪很管用(数量最重要). 原型

【秒懂设计模式】建造者模式

 秒懂设计模式--建造者模式 (四)建造者模式 1.先解释一下,什么是建造者模式呢? [官方定义]将一个复杂对象的构建,与它的表示分离,使得同样的构建过程可以创建不同的表示. [理解]官方定义过于抽象,让我们把它做一个拆分,分解成四个方面理解: ①复杂对象的表示: ②复杂对象的构建过程: ③可分离的通用构建过程,也适用于其它复杂对象的表示: ④适用于一些基本部件不会变,而其组合经常变化的时候. 2.接着,让我们再伴随一个例子,进一步清晰的理解这个定义: [举例]常去KFC的朋友,一般都会发现,其