原型模式

科技工作者之家 2020-11-17

用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。

定义原型模式是一种创建型设计模式,Prototype模式允许一个对象再创建另外一个可定制的对象,根本无需知道任何如何创建的细节,工作原理是:通过将一个原型对象传给那个要发动创建的对象,这个要发动创建的对象通过请求原型对象拷贝它们自己来实施创建。1

解决问题它主要面对的问题是:“某些结构复杂的对象”的创建工作;由于需求的变化,这些对象经常面临着剧烈的变化,但是他们却拥有比较稳定一致的接口。2

如何使用因为Java中的提供clone()方法来实现对象的克隆,所以Prototype模式实现一下子变得很简单。

以勺子为例:

public abstract class AbstractSpoon implements Cloneable{String spoonName;public void setSpoonName(String spoonName) {this.spoonName = spoonName;}public String getSpoonName() {return this.spoonName;}public Object clone(){Object object = null;try {object = super.clone();} catch (CloneNotSupportedException exception) {System.err.println("AbstractSpoon is not Cloneable");}return object;}}有两个具体实现(ConcretePrototype):public class SoupSpoon extends AbstractSpoon{public SoupSpoon(){setSpoonName("Soup Spoon");}}调用Prototype模式很简单:

AbstractSpoon spoon = new SoupSpoon();AbstractSpoon spoon = new SaladSpoon();当然也可以结合工厂模式来创建AbstractSpoon实例。

在Java中Prototype模式变成clone()方法的使用,由于Java的纯洁的面向对象特性,使得在Java中使用设计模式变得很自然,两者已经几乎是浑然一体了。这反映在很多模式上,如Iterator遍历模式。

带Prototype Manager的原型模式:客户(Client)角色:客户端类向原型管理器提出创建对象的请求。

抽象原型(Prototype)角色:这是一个抽象角色,通常由一个C#接口或抽象类实现。此角色给出所有的具体原型类所需的接口。在C#中,抽象原型角色通常实现了ICloneable接口。

具体原型(Concrete Prototype)角色:被复制的对象。此角色需要实现抽象的原型角色所要求的接口。

原型管理器(Prototype Manager)角色:创建具体原型类的对象,并记录每一个被创建的对象。1

代码实现如下:

/ CplusplusPrototype.cpp : Defines the entry point for the console application.//#include "stdafx.h"#include#include#includeusingnamespace std;//父类class Resume{protected:char *name;public:Resume() {}virtual ~Resume() {}virtual Resume* Clone() { return NULL; }virtualvoid Set(char *n) {}virtualvoid Show() {}};class ResumeA : public Resume{public:ResumeA(constchar *str); //构造函数ResumeA(const ResumeA &r); //拷贝构造函数~ResumeA(); //析构函数ResumeA* Clone(); //克隆,关键所在void Show(); //显示内容};ResumeA::ResumeA(constchar *str){if(str == NULL) {name = newchar[1];name[0] = '\0';}else {name = newchar[strlen(str)+1];strcpy(name, str);}}ResumeA::~ResumeA() { delete [] name;}ResumeA::ResumeA(const ResumeA &r) {name = newchar[strlen(r.name)+1];strcpy(name, r.name);}ResumeA* ResumeA::Clone() {returnnew ResumeA(*this);}void ResumeA::Show() {coutShow();delete r3; delete r4;r3 = r4 = NULL;return 0;}本词条内容贡献者为:

曹慧慧 - 副教授 - 中国矿业大学

科技工作者之家

科技工作者之家APP是专注科技人才,知识分享与人才交流的服务平台。