028-86261949

当前位置:首页 > 技术交流 > 原型模式_prototype

原型模式_prototype

2020/01/15 09:48 分类: 技术交流 浏览:1

原型模式概述

在java中创建一个对象通过new是非常繁琐的,需要创建检查权限,做一些数据准备等等,因此也会销毁系统性能,那么想要快快速简单的创建出对象,我们可以通过原型模式实现,以某个对象为原型,显然新的对象具备原型对象的特点。new的对象采用的是默认值,而通过原型克隆的对象与原型对象存在一模一样的值。我们可以修改克隆对象的值,原型:早在js中就存在原型概念一说,是否还有印象,克隆,原至1997年英国克隆羊多利。克隆可以简单理解为复制

 

Java中如何实现原型模式:

首先需要克隆的对象,必须实现Cloneable接口,和clone方法。代码对象克隆是一个比较复杂的过程,但是Object为我们提供了clone方法,显然我们操作起来会方便很多

克隆我们分为浅度克隆 和 深度克隆:我们分别了解一下

代码清单:【实现接口覆写clone方法对象调用实现浅度克隆】通过对象调用clone方法实现复制一个新的对象

public class Pig implements Cloneable{

       private Date birthday;

       @Override

       protected Pig clone() throws CloneNotSupportedException {//浅度克隆

              Pig pig = (Pig)super.clone();

              return pig;

       }

       public Date getBirthday() {

              return birthday;

       }

       public void setBirthday(Date birthday) {

              this.birthday = birthday;

       }

       public Pig(){ 

       }

}

测试代码:

Date date = new Date();

     

      Pig pig = new Pig();

      pig.setBirthday(date);

      System.out.println(pig);

     

      Pig clone = pig.clone();

   System.out.println(clone);

结果:

cn.itsource.Pig@6d9c638

cn.itsource.Pig@7dc5e7b4

问题:由于是浅度克隆,所以其实原型对象和复制的对象,其实引用的同一个日期对象

 

代码清单:【实现接口覆写clone方法对象调用实现浅度克隆】通过对象调用clone方法实现复制一个新的对象

public class Pig implements Cloneable{

       private Date birthday;

       @Override

       protected Pig clone() throws CloneNotSupportedException {

              Pig pig = (Pig)super.clone();

pig.setBirthDay = this.birthDay.clone();//实现深度克隆

              return pig;

       }

       public Date getBirthday() {

              return birthday;

       }

       public void setBirthday(Date birthday) {

              this.birthday = birthday;

       }

       public Pig(){ 

       }

}

如上代码所示:我们只需要对对象属性进行再次克隆,付给克隆对象即可

总结:实际开发中,由于自己new对象:设计的复杂读,数据准备权限减产等等,实际开发中克隆还是用的比较多。

#标签:原型模式,浅度克隆,深度克隆