设计模式 原型模式(Prototype)

2018-03-01 11:16:53来源:oschina作者:wangchen1999人点击

分享

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


publicclassPrototypeimplementsCloneable{
publicObjectclone()throwsCloneNotSupportedException{
Prototypeproto=(Prototype)super.clone();
returnproto;
}
}

很简单,一个原型类,只需要实现Cloneable接口,覆写clone方法,此处clone方法可以改成任意的名称,因为Cloneable接口是个空接口,你可以任意定义实现类的方法名,如cloneA或者cloneB,因为此处的重点是super.clone()这句话,super.clone()调用的是Object的clone()方法,而在Object类中,clone()是native的,具体怎么实现,我会在另一篇文章中,关于解读Java中本地方法的调用,此处不再深究。在这儿,我将结合对象的浅复制和深复制来说一下,首先需要了解对象深、浅复制的概念:


浅复制:将一个对象复制后,基本数据类型的变量都会重新创建,而引用类型,指向的还是原对象所指向的。


深复制:将一个对象复制后,不论是基本数据类型还有引用类型,都是重新创建的。简单来说,就是深复制进行了完全彻底的复制,而浅复制不彻底。


此处,写一个深浅复制的例子:


publicclassPrototypeimplementsCloneable,Serializable{
privatestaticfinallongserialVersionUID=1L;
privateStringstring;
privateSerializableObjectobj;
/*浅复制*/
publicObjectclone()throwsCloneNotSupportedException{
Prototypeproto=(Prototype)super.clone();
returnproto;
}
/*深复制*/
publicObjectdeepClone()throwsIOException,ClassNotFoundException{
/*写入当前对象的二进制流*/
ByteArrayOutputStreambos=newByteArrayOutputStream();
ObjectOutputStreamoos=newObjectOutputStream(bos);
oos.writeObject(this);
/*读出二进制流产生的新对象*/
ByteArrayInputStreambis=newByteArrayInputStream(bos.toByteArray());
ObjectInputStreamois=newObjectInputStream(bis);
returnois.readObject();
}
publicStringgetString(){
returnstring;
}
publicvoidsetString(Stringstring){
this.string=string;
}
publicSerializableObjectgetObj(){
returnobj;
}
publicvoidsetObj(SerializableObjectobj){
this.obj=obj;
}
}
classSerializableObjectimplementsSerializable{
privatestaticfinallongserialVersionUID=1L;
}

要实现深复制,需要采用流的形式读入当前对象的二进制输入,再写出二进制数据对应的对象。


我们接着讨论设计模式,上篇文章我讲完了5种创建型模式,这章开始,我将讲下7种结构型模式:适配器模式、装饰模式、代理模式、外观模式、桥接模式、组合模式、享元模式。其中对象的适配器模式是各种模式的起源,我们看下面的图:


最新文章

123

最新摄影

闪念基因

微信扫一扫

第七城市微信公众平台