【设计模式】4、原型模式

代码示例:

 1 package com.shejimoshi.create.Prototype;
 2
 3
 4 /**
 5  * 功能:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象
 6  * 适用:当一个系统应该独立于她得产品创建、构成和表示时,要使用Prototype模式
 7  *         实例化的类是在运行时刻指定的
 8  *         避免创建一个与产品类层次平行的工厂类层次时
 9  *         当一个类的实例只能有几个不同状态组合中的一种的时候
10  * 时间:2016年2月14日下午7:27:39
11  * 作者:cutter_point
12  */
13 public interface Prototype
14 {
15     //克隆自己
16     public Prototype Clone();
17     public void display();
18 }

实现接口:

 1 package com.shejimoshi.create.Prototype;
 2
 3
 4 /**
 5  * 功能:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象
 6  * 适用:当一个系统应该独立于她得产品创建、构成和表示时,要使用Prototype模式
 7  *         实例化的类是在运行时刻指定的
 8  *         避免创建一个与产品类层次平行的工厂类层次时
 9  *         当一个类的实例只能有几个不同状态组合中的一种的时候
10  * 时间:2016年2月14日下午7:32:27
11  * 作者:cutter_point
12  */
13 public class Prototype1 implements Prototype
14 {
15     private String name;
16     private int id;
17
18     //构造函数
19     public Prototype1(String name, int id)
20     {
21         this.name = name;
22         this.id =id;
23     }
24
25     //拷贝构造函数
26     public Prototype1(Prototype1 p1)
27     {
28         this.name = p1.name;
29         this.id = p1.id;
30     }
31
32     @Override
33     public Prototype Clone()
34     {
35         //拷贝自己,深拷贝还是浅拷贝,在我们的拷贝构造函数中定义
36         return new Prototype1(this);
37     }
38
39     @Override
40     public void display()
41     {
42         System.out.println("Prototype1的名字和id是:" + this.name + " : " + this.id);
43     }
44
45 }
 1 package com.shejimoshi.create.Prototype;
 2
 3
 4 /**
 5  * 功能:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象
 6  * 适用:当一个系统应该独立于她得产品创建、构成和表示时,要使用Prototype模式
 7  *         实例化的类是在运行时刻指定的
 8  *         避免创建一个与产品类层次平行的工厂类层次时
 9  *         当一个类的实例只能有几个不同状态组合中的一种的时候
10  * 时间:2016年2月14日下午7:36:23
11  * 作者:cutter_point
12  */
13 public class Prototype2 implements Prototype
14 {
15     private String name;
16     private int id;
17
18     //构造函数
19     public Prototype2(String name, int id)
20     {
21         this.name = name;
22         this.id =id;
23     }
24
25     //拷贝构造函数
26     public Prototype2(Prototype2 p2)
27     {
28         this.name = p2.name;
29         this.id = p2.id;
30     }
31
32     @Override
33     public Prototype Clone()
34     {
35         //拷贝自己,深拷贝还是浅拷贝,在我们的拷贝构造函数中定义
36         return new Prototype2(this);
37     }
38
39     @Override
40     public void display()
41     {
42         System.out.println("Prototype2的名字和id是:" + this.name + " : " + this.id);
43     }
44 }

客户端,测试代码:

 1 package com.shejimoshi.create.Prototype;
 2
 3
 4 /**
 5  * 功能:客户端程序测试
 6  * 时间:2016年2月14日下午7:37:27
 7  * 作者:cutter_point
 8  */
 9 public class Test
10 {
11     public static void main(String args[])
12     {
13         Prototype obj1 = new Prototype1("cutter", 1);
14         Prototype obj2 = obj1.Clone();
15         Prototype obj3 = obj2.Clone();
16
17         obj1.display();
18         obj2.display();
19         obj3.display();
20
21         //类似的第二个对象
22         Prototype obj4 = new Prototype2("point", 2);
23         Prototype obj5 = obj4.Clone();
24         Prototype obj6 = obj5.Clone();
25
26         obj4.display();
27         obj5.display();
28         obj6.display();
29
30     }
31 }

输出结果:

Prototype1的名字和id是:cutter : 1
Prototype1的名字和id是:cutter : 1
Prototype1的名字和id是:cutter : 1
Prototype2的名字和id是:point : 2
Prototype2的名字和id是:point : 2
Prototype2的名字和id是:point : 2
时间: 2024-11-03 05:28:51

【设计模式】4、原型模式的相关文章

【设计模式】——原型模式

原型模式(Prototype),用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象. 下图是原型模式的结构图: 原型模型其实就是一个对象再创建另外一个可定制的对象,而且不需任何创建的细节,我们来看看基本的原型模式代码. //原型类 class Prototype { private: string id; public: Prototype(string id) { this->id=id; } string GetId() { return id; } virtual Protot

大话设计模式_原型模式(Java代码)

原型模式:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象 简单描述:即通过实现接口Cloneable重写方法clone(),使得创建新的拷贝对象不需要一个成员一个成员的重新复制,而且可以提高创建对象的效率 Java中要想实现拷贝使用clone()方法,类必须实现Cloneable接口,并且重写Object类中的clone()方法,调用父类的clone()方法即可实现浅复制 代码如下: WorkExperience类: 1 package com.longsheng.prototy

大话设计模式之原型模式

原型模式 定义: 用原型实例制定创建对象的种类,并通过拷贝这些原型,创建新的对象. 实质: 就是从一个对象在创建另一个可定制的对象,而且不需要知道任何创建的细节. 核心: (1).实现Cloneable接口,可以使用此接口的类上使用clone方法. (2).重写Object类中的clone方法,因为所有类的父类是Object类,Object有一个clone方法,作用是返回对象的一个拷贝,但是其作用域protected类型的,一般的类无法调用,因此,将clone改为public类型. 结构图: 代

深入浅出设计模式 ------ Prototype(原型模式)之深度克隆

继上篇深入浅出设计模式 ------ Prototype(原型模式)的浅克隆实现, 本文进入Prototype(原型模式)的进阶篇----深度克隆. 深度克隆 ---- 序列化方式实现 把对象写到流里的过程是序列化(Serilization)过程,而把对象从流中读出来的过程则叫做反序列化(Deserialization).写在流里的是对象的一个克隆(新的, 独立的), 而原对象仍存在于JVM内存模型里.因此, 以下代码采用序列化方式实现深度克隆. 第一步: 将上篇的代码做些许改动, 加入对象引用

C#设计模式(6)——原型模式(Prototype Pattern)

一.引言 在软件系统中,当创建一个类的实例的过程很昂贵或很复杂,并且我们需要创建多个这样类的实例时,如果我们用new操作符去创建这样的类实例,这未免会增加创建类的复杂度和耗费更多的内存空间,因为这样在内存中分配了多个一样的类实例对象,然后如果采用工厂模式来创建这样的系统的话,随着产品类的不断增加,导致子类的数量不断增多,反而增加了系统复杂程度,所以在这里使用工厂模式来封装类创建过程并不合适,然而原型模式可以很好地解决这个问题,因为每个类实例都是相同的,当我们需要多个相同的类实例时,没必要每次都使

图解Java设计模式之原型模式

图解Java设计模式之原型模式 克隆羊的问题 原型模式 - 基本介绍 原型模式在Spring框架中源码分析 浅拷贝的介绍 深拷贝基本介绍 克隆羊的问题 现在有一只羊tom,姓名为 : tom,年龄为 :1,颜色为 :白色,请编写程序创建和tom羊属性完全相同的10只羊. 传统方式解决克隆羊的问题 package com.example.demo.prototype; public class Sheep { private String name; private int age; privat

设计模式之原型模式(Prototype)

1.初识原型模式 大家都知道连锁机构是现在灰常流行的商业模式,比如咖啡之翼,那么假设咖啡之翼要在长春新建立一个分店,所经营的产品和以前在其他的城市已经存在的店经营的产品差不多,那么面向对象开发的角度怎么解决这个问题呢?难道要重新的实例化一个咖啡之翼的店??这显然不太好吧,咖啡之翼里面经营的产品(假设是属性吧)都需要重新写,这就是在做大量的重复工作啊,这显然是不符合OO开发思想的.遇到这样的情况,并不是重新建立一个类来解决这样的问题,而是通过设计模式中的"原型模式"来解决这种问题.是这种

Java设计模式之原型模式

原型模式简介 原型模式实际上不算一种设计模式,应该说是一种技巧吧.当我们需要创建与已有对象一样的对象时,我们通常可以有两种容易想到的方法,一种是将已有对象指向另外一个重新创建的对象,如 //将old赋给new Object newObject=oldObject; 这种做法是相当于newObject还是指向oldObject的地址,也就是说,二者实际上是一样的,未来也是一样的,随便对哪个对象进行更改,二者都会保持一致,因为可以把它们看做两个相同的"指针":另外一种常见的做法是,重新创建

<六>读<<大话设计模式>>之原型模式

原型模式也是很简单的一种模式,对于java来说已经有相应的接口了(Cloneable).关于原型模式<<大话设计模式>>是以投放简历作为例子讲解的,即我要投放很多简历,其实每个简历都一样,所以只要我写好一份,其他的复制就行了,其实就是今天讲的原型模式,就是把要复制的类对象的属性复制到另外一个对象上(其实不是复制而是对象的引用改变). 原型模型:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象. 浅复制VS深复制 关于克隆有两个概念 浅复制:就是只复制值类型的字段,不能

设计模式之原型模式(c++)

问题描述 看到这个模式,很容易想到小时候看的<西游记>,齐天大圣孙悟空发飙的时候可以通过自己头上的 3 根毛立马复制出来成千上万的孙悟空, 对付小妖怪很管用(数量最重要). Prototype 模式也正是提供了自我复制的功能, 就是说新对象的创建可以通过已有对象进行创建.在 C++中,拷贝构造函数( Copy Constructor) 曾经是很对程序员的噩梦,浅层拷贝和深层拷贝的魔魇也是很多程序员在面试时候的快餐和系统崩溃时候的根源之一. 在GOF的<设计模式:可复用面向对象软件的基础&