原型模式:使用原型实例指定待创建对象的类型,并且通过复制这个原型来创建新的对象

分析:

孙悟空:根据自己的形状复制(克隆)出多个身外身
软件开发:通过复制一个原型对象得到多个与原型对象一模一样的新对象
 
 
工作原理:将一个原型对象传给要发动创建的对象(即客户端对象),这个要发动创建的对象通过请求原型对象复制自己来实现创建过程
创建新对象(也称为克隆对象)的工厂就是原型类自身,工厂方由负责复制原型对象的克隆方法来实现
通过克隆方法所创建的对象是全新的对象,它们在内存中拥有新的地址,每一个克隆对象都是独立
通过不同的方式对克隆对象进行修改以后,可以得到一系列相似但不完全相同的对象
 
原型模式的结构
原型模式包含以下3个角色:
•Prototype(抽象原型类)
•ConcretePrototype(具体原型类)
•Client(客户类)
 
浅克隆与深克隆
浅克隆(Shallow Clone)当原型对象被复制时,只复制它本身和其中包含的值类型的成员变量,而引用类型的成员变量并没有复制
深克隆(Deep Clone)除了对象本身被复制外,对象所包含的所有成员变量也将被复制
 
 
案例:
  1. [Serializable] //深克隆时需要将类标记为Serializable
  2. public class Person:ICloneable
  3. {
  4. public string CurrentEmployee { get; set; }
  5. public Member Member { get; set; }
  6. public Person()
  7. {
  8. this.CurrentEmployee = "admin";
  9. Member member = new Member();
  10. member.Id = ;
  11. member.Name = "Mem";
  12. this.Member = member;
  13. }
  14. public object Clone()
  15. {
  16. return this.MemberwiseClone();
  17. }
  18. #region 静态方式创建对象
  19. private static Person _person;
  20. /// <summary>
  21. /// 静态构造函数,永远只运行一次
  22. /// </summary>
  23. static Person()
  24. {
  25. _person = new Person();
  26. }
  27. public static Person StaticClone()
  28. {
  29. return _person.MemberwiseClone() as Person;
  30. }
  31. #endregion
  32. }
  1. [Serializable]
  2. public class Member
  3. {
  4. public int Id { get; set; }
  5. public string Name { get; set; }
  6. }
  1. public class SerializeHelper
  2. {
  3. /// <summary>
  4. /// 序列化
  5. /// </summary>
  6. /// <param name="target"></param>
  7. /// <returns></returns>
  8. public static string Serializable(object target)
  9. {
  10. using(MemoryStream stream=new MemoryStream())
  11. {
  12. new BinaryFormatter().Serialize(stream,target);
  13. return Convert.ToBase64String(stream.ToArray());
  14. }
  15. }
  16. /// <summary>
  17. /// 反序列化
  18. /// </summary>
  19. /// <typeparam name="T"></typeparam>
  20. /// <param name="target"></param>
  21. /// <returns></returns>
  22. public static T Derializable<T>(string target)
  23. {
  24. byte[] targetArray = Convert.FromBase64String(target);
  25. using (MemoryStream stream = new MemoryStream(targetArray))
  26. {
  27. return (T)(new BinaryFormatter().Deserialize(stream));
  28. }
  29. }
  30. /// <summary>
  31. /// 合并反序列化与序列化
  32. /// </summary>
  33. /// <typeparam name="T"></typeparam>
  34. /// <param name="t"></param>
  35. /// <returns></returns>
  36. public static T DeepClone<T>(T t)
  37. {
  38. return Derializable<T>(Serializable(t));
  39. }
  40. }

调用:

  1. //浅表克隆,原来创建的对象值会改变
  2. Person p = new Person();
  3. Person p1 = p.Clone() as Person;
  4. p1.CurrentEmployee = "user";
  5. p1.Member.Id = ;
  6. p1.Member.Name = "pp1";
  7. //深度克隆,原来创建的对象值不会改变
  8. Person p2 = p.Clone() as Person;
  9. Person p3 = SerializeHelper.Derializable<Person>(SerializeHelper.Serializable(p2));
  10. //或者简写
  11. //Person p3 = SerializeHelper.DeepClone<Person>(p2);
  12. p3.Member.Id = ;
  13. p3.Member.Name = "dd3";
  14. Console.Read();

C#设计模式之原型模式的更多相关文章

  1. 设计模式_11_原型模式(prototype)深拷贝、浅拷贝

    设计模式_11_原型模式(prototype) 浅拷贝: package designPatternOf23; /** * 定义:用原型实例,指定创建对象的种类,并通过拷贝这些原型创建新的对象 * P ...

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

    一.引言 在软件系统中,当创建一个类的实例的过程很昂贵或很复杂,并且我们需要创建多个这样类的实例时,如果我们用new操作符去创建这样的类实例,这未免会增加创建类的复杂度和耗费更多的内存空间,因为这样在 ...

  3. 乐在其中设计模式(C#) - 原型模式(Prototype Pattern)

    原文:乐在其中设计模式(C#) - 原型模式(Prototype Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 原型模式(Prototype Pattern) 作者:weba ...

  4. C#设计模式之六原型模式(Prototype)【创建型】

    一.引言 在开始今天的文章之前先说明一点,欢迎大家来指正.很多人说原型设计模式会节省机器内存,他们说是拷贝出来的对象,这些对象其实都是原型的复制,不会使用内存.我认为这是不对的,因为拷贝出来的每一个对 ...

  5. C#设计模式之五原型模式(Prototype Pattern)【创建型】

    一.引言 在开始今天的文章之前先说明一点,欢迎大家来指正.很多人说原型设计模式会节省机器内存,他们说是拷贝出来的对象,这些对象其实都是原型的复制,不会使用内存.我认为这是不对的,因为拷贝出来的每一个对 ...

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

    一.引言 在软件系统中,当创建一个类的实例的过程很昂贵或很复杂,并且我们需要创建多个这样类的实例时,如果我们用new操作符去创建这样的类实例,这未免会增加创建类的复杂度和耗费更多的内存空间,因为这样在 ...

  7. C#设计模式(6)——原型模式(Prototype Pattern) C# 深浅复制 MemberwiseClone

    C#设计模式(6)——原型模式(Prototype Pattern)   一.引言 在软件系统中,当创建一个类的实例的过程很昂贵或很复杂,并且我们需要创建多个这样类的实例时,如果我们用new操作符去创 ...

  8. JAVA 设计模式之原型模式

    目录 JAVA 设计模式之原型模式 简介 Java实现 1.浅拷贝 2.深拷贝 优缺点说明 1.优点 2.缺点 JAVA 设计模式之原型模式 简介 原型模式是六种创建型设计模式之一,主要应用于创建相同 ...

  9. C# Json反序列化 C# 实现表单的自动化测试<通过程序控制一个网页> 验证码处理类:UnCodebase.cs + BauDuAi 读取验证码的值(并非好的解决方案) 大话设计模式:原型模式 C# 深浅复制 MemberwiseClone

    C# Json反序列化   Json反序列化有两种方式[本人],一种是生成实体的,方便处理大量数据,复杂度稍高,一种是用匿名类写,方便读取数据,较为简单. 使用了Newtonsoft.Json,可以自 ...

  10. GOF23设计模式之原型模式

    GOF23设计模式之原型模式 1)通过 new 产生一个对象需要飞船繁琐的数据准备或访问权限,则可以使用原型模式. 2)就算 java 中的克隆技术,以某个对象为原型,复制出新的对象.显然,新的对象具 ...

随机推荐

  1. 关于Array的map方法中回调函数参数的问题

    开门见山,我们先来看两个例子. var arr=['1','4','9','16']; var r=arr.map(Math.sqrt); 猜猜r的结果会是多少? 没错就是 [1,2,3,4] 我们再 ...

  2. ThinkPhp 3.2 自动验证

    自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证. 数据验证有两种方式: 静态方式:在模型类里面通过$_validate属性定义验证规则 ...

  3. CCS5.2/CCS5.3/CCS5.4 仿真调试小技巧

    操作系统: WinXP 32bit 仿真器: SEED-XDS560 Plus 开发环境: DSP.com/forum.php?mod=forumdisplay&fid=58" ta ...

  4. .vue文件里引用单独样式和js文件

    style只能引一个,script可以引多个

  5. Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' heade

    XMLHttpRequest cannot load http://10.164.153.37:8050/WebService/WebService.asmx/wsGetStreetData. Res ...

  6. java的锁机制

    一段synchronized的代码被一个线程执行之前,他要先拿到执行这段代码的权限,在Java里边就是拿到某个同步对象的锁(一个对象只有一把锁): 如果这个时候同步对象的锁被其他线程拿走了,他(这个线 ...

  7. 深入理解android:id以及@+id/name和@id/name的区别联系

    今天为了好好研究了下@+id/name和@id/name的区别以及联系,又翻了翻文档/guide/topics/resources/layout-resource.html中关于 android:id ...

  8. 学习 opencv---(7) 线性邻域滤波专场:方框滤波,均值滤波,高斯滤波

    本篇文章中,我们一起仔细探讨了OpenCV图像处理技术中比较热门的图像滤波操作.图像滤波系列文章浅墨准备花两次更新的时间来讲,此为上篇,为大家剖析了"方框滤波","均值滤 ...

  9. 将Vuforia程序发布到Windows10系统的基本流程

    最新博客地址已转到: http://blog.csdn.net/zzlyw?viewmode=contents   ------------------------------------------ ...

  10. HTTP Status 400 - Required String parameter 'userName' is not present 错误

    HTTP Status 400 - Required String parameter 'userName' is not present 错误 先mark  有时间详细写 参考链接: https:/ ...