原型模式
- 通过new产生一个对象需要非常繁琐的数据准备或访问权限,则可以使用原型模式
- 就是java中的克隆技术,以某个对象为原型,复制出新的对象,显然,新的对象具备原型对象的特点
- 优势有:效率高可以直接克隆,避免了重新执行构造过程步骤
- 克隆类似于new,但是不同于new。nei创建新的对象属性采用的是默认值,克隆出的对象的属性值完全和原型对象相同,并且克隆出的新对象改变不会影响原型对象,然后再修改克隆对象的值。
原型模式实现方式
- Cloneable接口和clone方法
- Prototype模式中实现起来最困难的地方就是内存复制操作,所幸在Java中提供了clone()方法替我们做了绝大部分事情
浅克隆
public class Sheep implements Cloneable { private String sname ; //1997年英国多利诞生 private Date birthday ; public Sheep(String sname, Date birthday){ super(); this.sname = sname; this.birthday = birthday; } @Override protected Object clone() throws CloneNotSupportedException { return super.clone();//返回羊对象 } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } } public class Client { public static void main(String[] args) throws CloneNotSupportedException { Date date1 = new Date(); Sheep xyy = new Sheep("喜洋洋",date1); Sheep doly = (Sheep)xyy.clone(); date1.setTime(123123123L); //date1 变 xyy 与 doly的birthday都跟着改变 。。。。浅拷贝 System.out.println(xyy); System.out.println(doly); System.out.println(xyy.getSname()); System.out.println(xyy.getBirthday()); System.out.println(doly.getSname()); System.out.println(doly.getBirthday()); } }
深克隆
public class Sheep2 implements Cloneable { private String sname ; //1997年英国多利诞生 private Date birthday ; public Sheep2(String sname, Date birthday){ super(); this.sname = sname; this.birthday = birthday; } @Override protected Object clone() throws CloneNotSupportedException { Object obj = super.clone(); //添加如下代码实现深复制 Sheep2 s = ((Sheep2) obj); s.birthday = (Date)this.birthday.clone(); return s;//返回羊对象 } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } } public class DeepClient { public static void main(String[] args) throws CloneNotSupportedException { Date date1 = new Date(); Sheep2 xyy = new Sheep2("喜洋洋", date1); Sheep2 doly = (Sheep2)xyy.clone(); date1.setTime(123123123L); // doly.setSname("多利"); // doly.setBirthday(date1); System.out.println(xyy); System.out.println(doly); System.out.println(xyy.getSname()); System.out.println(xyy.getBirthday()); System.out.println(doly.getSname()); System.out.println(doly.getBirthday()); } }
利用序列化和反序列化实现深克隆
需要实现Serializable接口
public class Sheep implements Cloneable,Serializable { private String sname ; //1997年英国多利诞生 private Date birthday ; public Sheep(String sname, Date birthday){ super(); this.sname = sname; this.birthday = birthday; } @Override protected Object clone() throws CloneNotSupportedException { return super.clone();//返回羊对象 } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } }
通过 IO 流来实现深度拷贝
/** * 使用序列化和反序列化的方式实现深克隆 */ public class Client3 { public static void main(String[] args) throws CloneNotSupportedException, IOException, ClassNotFoundException { Date date1 = new Date(); Sheep xyy = new Sheep("喜洋洋",date1); System.out.println("喜洋洋修改之前的参数"); System.out.println(xyy); System.out.println(xyy.getSname()); System.out.println(xyy.getBirthday()); //doly 通过反序列接口获得 ByteArrayOutputStream bos = new ByteArrayOutputStream(); ObjectOutputStream oos = new ObjectOutputStream(bos); oos.writeObject(xyy); byte[] bytes = bos.toByteArray(); ByteArrayInputStream bis = new ByteArrayInputStream(bytes); ObjectInputStream ois = new ObjectInputStream(bis); Sheep doly = (Sheep)ois.readObject(); System.out.println("修改之后喜洋洋的参数"); date1.setTime(123123123L); //date1 变 xyy发生变化 System.out.println(xyy); System.out.println(xyy.getSname()); System.out.println(xyy.getBirthday()); System.out.println("修改之后多利的参数"); //深拷贝之后doly不变 System.out.println(doly); System.out.println(doly.getSname()); System.out.println(doly.getBirthday()); } }
- 如果需要短时间创建大量的对象,并且通过new的过程比较耗时,可以考虑原型模式,新建普通new方式创建对象和clone方式创建对象的效率差异
- 原型模式很少单独出现,一般是和工厂方法模式一起出现,通过clone方法创建一个对象然后由工厂方法提供给调用者
- spring中bean的创建实际就是两种:单例模式和原型模式,当然原型模式需要和工厂模式搭配使用适配器模式
相关推荐
【设计模式之原型模式】 设计模式是软件工程中的一种最佳实践,是对在特定上下文中反复出现的软件设计问题的解决方案。原型模式属于对象创建型模式,它的主要思想是通过复制已有对象来创建新对象,降低了类的实例化...
《设计模式之蝉》这本书可能是对设计模式的一种形象化描述,或是以蝉为比喻来讲解设计模式的概念。蝉在地下蛰伏多年,最终破土而出,仅生活在地面上的几周时间。这一生命周期与设计模式的持久价值有异曲同工之妙,即...
"设计模式之美——教你写出高质量代码"这个主题旨在帮助开发者更好地理解和应用设计模式,从而提升代码的质量和可维护性。设计模式不仅对面试有所帮助,也是职场发展中的必备技能,无论你使用哪种开发语言。 设计...
《Java设计模式之禅》是一本深入浅出讲解设计模式的书籍,书中不仅包含23种经典设计模式的案例,还详细介绍了设计模式背后的思想和原则,适合初学者以及对设计模式有一定了解的程序员阅读。本书旨在帮助读者理解如何...
在这个“设计模式之美”的学习笔记中,我们将探讨一些主要的设计模式,以及它们在实际开发中的应用。 首先,我们从创建型模式开始。这类模式主要用于对象的创建,如单例模式(Singleton)、工厂模式(Factory ...
原型模式(Prototype Pattern)是一种创建型设计模式,允许通过复制现有对象来创建新对象,而不是通过类构造器。这种模式常用于需要频繁创建相似对象的场景,能够提高性能并减少内存使用。 原型模式的组成 原型接口...
设计模式 的分类 总体来说设计模式分为三大类: 创建型模式(5): 工厂方法模式 、抽象工厂模式、单例模式、建造者模式、原型模式。 结构型模式(7): 适配器模式、装饰器模式、代理模式、外观模式、桥接模式、...
设计模式之《大话设计模式》.pptx
Java 经典设计模式讲解以及项目实战 设计模式简介:主要介绍各种设计模式的概念和运用场景等 设计模式综合运用:主要是笔者在实际工作中运用到的一些设计模式综合运用事例的提炼 Spring设计模式简介:主要是讲述...
设计模式是软件工程中的一种重要思想,它是在特定情境下,为解决常见问题而形成的一套最佳实践。在本文中,我们将深入探讨24种设计模式,并结合混合设计模式的概念,以及它们在实际项目中的应用案例。 首先,设计...
原型模式(Prototype Pattern)是软件设计模式中的一种结构型模式,它的主要目的是通过复制已有对象来创建新对象,从而减少创建新对象的成本。在原型模式中,类的实例化过程被替换为对已有实例的克隆操作,尤其适用...
人人都懂设计模式 设计模式是软件开发中的一种解决方案,它提供了一种通用的设计思想和方法论,可以帮助开发者更好地设计和实现软件系统。设计模式可以分为三大类:创建型模式、结构型模式和行为型模式。 在本书中...
本文将深入探讨Android设计模式中的“原型模式”(Prototype Pattern),并结合提供的"prototype"压缩包中的示例代码进行解析。 原型模式是一种创建型设计模式,它的主要思想是通过复制已有对象来创建新对象,而...
《Head First 设计模式》与《Java设计模式(第2版)》是两本非常重要的IT书籍,专注于软件开发中的设计模式。设计模式是解决软件设计中常见问题的经验总结,它们提供了一种标准的方法来处理特定场景下的问题,使得代码...
java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式...
#### 描述解析:设计模式的入门与精通之路 描述中提到设计模式和面向对象编程,强调了它们对于软件设计师和开发者的重要性。这表明书籍将从基础出发,逐步深入,不仅教授设计模式的基础知识,还将引导读者理解设计...