java设计模式-原型模式(PrototypePattern)

简介: java设计模式-原型模式(PrototypePattern)

设计模式系列

文章目录

前言

原型模式(Prototype Pattern)是用于创建重复的对象,同时又能保证性能。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。

这种模式是实现了一个原型接口,该接口用于创建当前对象的克隆。当直接创建对象的代价比较大时,则采用这种模式。例如,一个对象需要在一个高代价的数据库操作之后被创建。我们可以缓存该对象,在下一个请求时返回它的克隆,在需要的时候更新数据库,以此来减少数据库调用。

一、原型模式是什么?

把对象拷贝一份,产生一个新的对象,和原有对象一样。这种不通过new 关键字来产生一个对象,而是通过对象拷贝来实现的模式就叫做原型模式

二、使用步骤

1.实现cloneable接口对象的拷贝需要实现cloneable接口。

package java.lang;

/**

* A class implements the <code>Cloneable</code> interface to

* indicate to the {@link java.lang.Object#clone()} method that it

* is legal for that method to make a

* field-for-field copy of instances of that class.

* <p>

* Invoking Object's clone method on an instance that does not implement the

* <code>Cloneable</code> interface results in the exception

* <code>CloneNotSupportedException</code> being thrown.

* <p>

* By convention, classes that implement this interface should override

* <tt>Object.clone</tt> (which is protected) with a public method.

* See {@link java.lang.Object#clone()} for details on overriding this

* method.

* <p>

* Note that this interface does <i>not</i> contain the <tt>clone</tt> method.

* Therefore, it is not possible to clone an object merely by virtue of the

* fact that it implements this interface.  Even if the clone method is invoked

* reflectively, there is no guarantee that it will succeed.

*

* @author  unascribed

* @see     java.lang.CloneNotSupportedException

* @see     java.lang.Object#clone()

* @since   JDK1.0

*/

public interface Cloneable {

}

2.简单示例

代码如下(示例):

/**

* 简单的clone

*/

public class SimpleClone implements Cloneable{

   //属性问题

   private String props;

   public String getProps() {

       return props;

   }

   public void setProps(String props) {

       this.props = props;

   }

   /**

    * 克隆方法

    * @return

    * @throws CloneNotSupportedException

    */

   @Override

   protected SimpleClone clone()  {

       SimpleClone simpleClone = null;

       try {

           simpleClone = (SimpleClone)super.clone();

       } catch (CloneNotSupportedException e) {

           e.printStackTrace();

       }

       return simpleClone;

   }

}

测试:

public class Client {

   public static void main(String[] args) {

       SimpleClone simpleClone = new SimpleClone();

       System.out.println("原始对象"+simpleClone);

       SimpleClone clone = simpleClone.clone();

       System.out.println("原始对象"+simpleClone);

   }

}


866a0cfa94054175925c0fd5e80c42b7.png

浅拷贝

Object 类提供的方法clone 只是拷贝本对象,其对象内部的数组、引用对象等都不拷贝,还是指向原生对象的内部元素地址,这种拷贝就叫做浅拷贝

浅拷贝:


/**

* 浅拷贝

*/

public class ShallowClone implements Cloneable{

   //定义一个私有变量

   private ArrayList<String> props = new ArrayList<String>();

   public ArrayList<String> getProps() {

       return props;

   }

   public void setProps(String prop) {

       this.props.add(prop);

   }

   /**

    * 克隆方法

    * @return

    * @throws CloneNotSupportedException

    */

   @Override

   protected ShallowClone clone()  {

       ShallowClone shallowClone = null;

       try {

           shallowClone = (ShallowClone)super.clone();

       } catch (CloneNotSupportedException e) {

           e.printStackTrace();

       }

       return shallowClone;

   }

}

client:

public class ShallowClient {

   public static void main(String[] args) {

       ShallowClone shallowClone = new ShallowClone();

       shallowClone.setProps("浅拷贝前的对象属性值");

       ShallowClone clone = shallowClone.clone();

       clone.setProps("浅拷贝后的对象属性值");

       System.out.println(shallowClone.getProps());

   }

}

深拷贝

/**

* 深拷贝

*/

public class DeepClone implements Cloneable {

   //定义一个私有变量

   private ArrayList<String> props = new ArrayList<String>();

   public ArrayList<String> getProps() {

       return props;

   }

   public void setProps(String prop) {

       this.props.add(prop);

   }

   /**

    * 克隆方法

    * @return

    * @throws CloneNotSupportedException

    */

   @Override

   protected DeepClone clone()  {

       DeepClone deepClone = null;

       try {

           deepClone = (DeepClone)super.clone();

           //引用对象拷贝

           deepClone.props =  (ArrayList<String>)this.props.clone();

       } catch (CloneNotSupportedException e) {

           e.printStackTrace();

       }

       return deepClone;

   }

}

public class DeepClient {

   public static void main(String[] args) {

       DeepClone deepClone = new DeepClone();

       deepClone.setProps("浅拷贝前的对象属性值");

       DeepClone clone = deepClone.clone();

       clone.setProps("浅拷贝后的对象属性值");

       System.out.println(deepClone.getProps());

   }

}

52d558efb21449c99feb0d1b85225865.png

总结

一是类初始化需要消化非常多的资源,这个资源包括数据、硬件资源等;二是通过new 产生一个对象需要非常繁琐的数据准备或访问权限,则可以使用原型模式;三是一个对象需要提供给其他对象访问,而且各个调用者可能都需要修改其值时,可以考虑使用原型模式拷贝多个对象供调用者使用。在实际项目中,原型模式很少单独出现,一般是和工厂方法模式一起出现,通过clone的方法创建一个对象,然后由工厂方法提供给调用者


相关文章
|
23天前
|
设计模式 消息中间件 搜索推荐
Java 设计模式——观察者模式:从优衣库不使用新疆棉事件看系统的动态响应
【11月更文挑战第17天】观察者模式是一种行为设计模式,定义了一对多的依赖关系,使多个观察者对象能直接监听并响应某一主题对象的状态变化。本文介绍了观察者模式的基本概念、商业系统中的应用实例,如优衣库事件中各相关方的动态响应,以及模式的优势和实际系统设计中的应用建议,包括事件驱动架构和消息队列的使用。
|
1月前
|
设计模式 Java 数据库连接
Java编程中的设计模式:单例模式的深度剖析
【10月更文挑战第41天】本文深入探讨了Java中广泛使用的单例设计模式,旨在通过简明扼要的语言和实际示例,帮助读者理解其核心原理和应用。文章将介绍单例模式的重要性、实现方式以及在实际应用中如何优雅地处理多线程问题。
38 4
|
2月前
|
设计模式 Java 程序员
[Java]23种设计模式
本文介绍了设计模式的概念及其七大原则,强调了设计模式在提高代码重用性、可读性、可扩展性和可靠性方面的作用。文章还简要概述了23种设计模式,并提供了进一步学习的资源链接。
52 0
[Java]23种设计模式
|
1月前
|
设计模式 JavaScript Java
Java设计模式:建造者模式详解
建造者模式是一种创建型设计模式,通过将复杂对象的构建过程与表示分离,使得相同的构建过程可以创建不同的表示。本文详细介绍了建造者模式的原理、背景、应用场景及实际Demo,帮助读者更好地理解和应用这一模式。
|
2月前
|
设计模式 监控 算法
Java设计模式梳理:行为型模式(策略,观察者等)
本文详细介绍了Java设计模式中的行为型模式,包括策略模式、观察者模式、责任链模式、模板方法模式和状态模式。通过具体示例代码,深入浅出地讲解了每种模式的应用场景与实现方式。例如,策略模式通过定义一系列算法让客户端在运行时选择所需算法;观察者模式则让多个观察者对象同时监听某一个主题对象,实现松耦合的消息传递机制。此外,还探讨了这些模式与实际开发中的联系,帮助读者更好地理解和应用设计模式,提升代码质量。
Java设计模式梳理:行为型模式(策略,观察者等)
|
3月前
|
存储 设计模式 安全
Java设计模式-备忘录模式(23)
Java设计模式-备忘录模式(23)
|
3月前
|
设计模式 存储 算法
Java设计模式-命令模式(16)
Java设计模式-命令模式(16)
|
3月前
|
设计模式 存储 缓存
Java设计模式 - 解释器模式(24)
Java设计模式 - 解释器模式(24)
|
3月前
|
设计模式 安全 Java
Java设计模式-迭代器模式(21)
Java设计模式-迭代器模式(21)
|
3月前
|
设计模式 缓存 监控
Java设计模式-责任链模式(17)
Java设计模式-责任链模式(17)