A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© heshiwei 高级黑马   /  2015-10-8 12:32  /  181 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

原型模式虽然是创建型的模式,但是与工程模式没有关系,从名字即可看出,该模式的思想就是将一个对象作为原型,对其进行复制、克隆,产生一个和原对象类似的新对象。本小结会通过对象的复制,进行讲解。在Java中,复制对象是通过clone()实现的,先创建一个原型类:

  1. public class Prototype implements Cloneable {

  2.         public Object clone() throws CloneNotSupportedException {
  3.                 Prototype proto = (Prototype) super.clone();
  4.                 return proto;
  5.         }
  6. }
复制代码

很简单,一个原型类,只需要实现Cloneable接口,覆写clone方法,此处clone方法可以改成任意的名称,因为Cloneable接口是个空接口,你可以任意定义实现类的方法名,如cloneA或者cloneB,因为此处的重点是super.clone()这句话,super.clone()调用的是Object的clone()方法,而在Object类中,clone()是native的,具体怎么实现,我会在另一篇文章中,关于解读Java中本地方法的调用,此处不再深究。在这儿,我将结合对象的浅复制和深复制来说一下,首先需要了解对象深、浅复制的概念:
浅复制:将一个对象复制后,基本数据类型的变量都会重新创建,而引用类型,指向的还是原对象所指向的。
深复制:将一个对象复制后,不论是基本数据类型还有引用类型,都是重新创建的。简单来说,就是深复制进行了完全彻底的复制,而浅复制不彻底。
此处,写一个深浅复制的例子:


  1. public class Prototype implements Cloneable, Serializable {

  2.         private static final long serialVersionUID = 1L;
  3.         private String string;

  4.         private SerializableObject obj;

  5.         /* 浅复制 */
  6.         public Object clone() throws CloneNotSupportedException {
  7.                 Prototype proto = (Prototype) super.clone();
  8.                 return proto;
  9.         }

  10.         /* 深复制 */
  11.         public Object deepClone() throws IOException, ClassNotFoundException {

  12.                 /* 写入当前对象的二进制流 */
  13.                 ByteArrayOutputStream bos = new ByteArrayOutputStream();
  14.                 ObjectOutputStream oos = new ObjectOutputStream(bos);
  15.                 oos.writeObject(this);

  16.                 /* 读出二进制流产生的新对象 */
  17.                 ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray());
  18.                 ObjectInputStream ois = new ObjectInputStream(bis);
  19.                 return ois.readObject();
  20.         }

  21.         public String getString() {
  22.                 return string;
  23.         }

  24.         public void setString(String string) {
  25.                 this.string = string;
  26.         }

  27.         public SerializableObject getObj() {
  28.                 return obj;
  29.         }

  30.         public void setObj(SerializableObject obj) {
  31.                 this.obj = obj;
  32.         }

  33. }

  34. class SerializableObject implements Serializable {
  35.         private static final long serialVersionUID = 1L;
  36. }
复制代码
要实现深复制,需要采用流的形式读入当前对象的二进制输入,再写出二进制数据对应的对象。


0 个回复

您需要登录后才可以回帖 登录 | 加入黑马