设计模式-原型模式实例-浅克隆
浅克隆与深克隆:
浅克隆:
当对象被复制时,只复制它本身和其中包含的值类型的成员变量,而引用类型的成员变量未被复制。(Object.clone()方法)
深克隆:
对象本身及其包含的所有成员变量也将被复制。
(序列化,通过序列化对象将对象写到一个流中,再从流中读出来。原型必须实现Serializable接口(空接口/标识接口),才能序列化。)
注意:
x.clone() != x; //克隆对象和原型并非同一对象。
x.clone().getClass() == x.getClass(); //克隆对象与原对象类型一样。
如果equals()定义恰当,x.clone().equals(x);
要点:
当需要创建大量相同或相似对象时,可通过对一个已有对象的复制获取更多的对象(克隆/复制)。
通过克隆方法所创建的对象是全新的对象,拥有新的内存地址,是独立的。
优点:
简化对象创建过程,提高创建效率;
扩展性好;
简化创建结构,无须专门的工厂类;
可使用深克隆,保存对象状态,以便在需要的时候使用,可辅助实现撤销操作。
缺点:
每一个类需要一个克隆方法,对已有类改造时需修改源代码,违背开闭原则;
深克隆需编写一个较为复杂的代码。
适用环境:
创建新对象成本较大;
系统要保存对象的状态,而对象的状态变化很小;
避免使用分层次的工厂类创建分层次的对象。
实例1:邮件克隆(浅克隆)。
类图
代码实现:
代码结构:
Email.java:
//具体原型类
public class Email implements Cloneable{
private Attachment attachment = null;
public Email(){
this.attachment = new PrototypePattern.Attachment();
}
public Object clone(){
Email clone = null;
try {
clone = (Email) super.clone();
}catch (CloneNotSupportedException e){
System.out.println("Clone failurel");
}
return clone;
}
public Attachment getAttachment(){
return this.attachment;
}
public void display(){
System.out.println("read the email");
}
}
Attachment.java:
//附件类
public class Attachment {
public void download(){
System.out.println("download the fuemail");
}
}
Client.java:
public class Client {
public static void main(String[] args) {
Email email,copyEmail;
email = new Email();
copyEmail = (Email) email.clone();
System.out.println("email == copyEmail?");
System.out.println(email == copyEmail);
System.out.println("email.getAttachment == copyEmail.getAttachment?");
System.out.println(email.getAttachment() == copyEmail.getAttachment());
}
}
结论:
浅克隆只复制对象本身,不复制成员对象(附件)。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/128222.html