原型模式:
用原型实例指定创建对象的种类,并且通过复制这些原型创建新的对象。
主要的三个角色:
Prototype: 抽象原型类,声明克隆自身的接口
ConcretePrototype: 具体原型类,实现克隆的具体操作
CLient: 客户类,让一个原型克隆自身,从而获得一个新的对象。
public class Resume implements Cloneable {
private String name;
private String birthday;
private String sex;
private String school;
private String timeArea;
private String company;
/**
* 构造函数:初始化简历赋值姓名
*/
public Resume(String name){
this.name = name;
}
/**
* @desc 设定个人基本信息
* @param birthday 生日
* @param sex 性别
* @param school 毕业学校
* @return void
*/
public void setPersonInfo(String birthday,String sex,String school){
this.birthday = birthday;
this.sex = sex;
this.school = school;
}
/**
* @desc 设定工作经历
* @param timeArea 工作年限
* @param company 所在公司
* @return void
*/
public void setWorkExperience(String timeArea,String company){
this.timeArea = timeArea;
this.company = company;
}
/**
* 克隆该实例
*/
public Object clone(){
Resume resume = null;
try {
resume = (Resume) super.clone();
} catch (CloneNotSupportedException e) {
e.printStackTrace();
}
return resume;
}
public void display(){
System.out.println("姓名:" + name);
System.out.println("生日:" + birthday + ",性别:" + sex + ",毕业学校:" + school);
System.out.println("工作年限:" + timeArea + ",公司:" + company);
}
}
public class Client {
public static void main(String[] args) {
//原型A对象
Resume a = new Resume("小李子");
a.setPersonInfo("2.16", "男", "XX大学");
a.setWorkExperience("2012.09.05", "XX科技有限公司");
//克隆B对象
Resume b = (Resume) a.clone();
//输出A和B对象
System.out.println("----------------A--------------");
a.display();
System.out.println("----------------B--------------");
b.display();
/*
* 测试A==B?
* 对任何的对象x,都有x.clone() !=x,即克隆对象与原对象不是同一个对象
*/
System.out.print("A==B?");
System.out.println( a == b);
/*
* 对任何的对象x,都有x.clone().getClass()==x.getClass(),即克隆对象与原对象的类型一样。
*/
System.out.print("A.getClass()==B.getClass()?");
System.out.println(a.getClass() == b.getClass());
}
}
优点:
可以屏蔽掉创建新对象的复杂性
可以使用深克隆来保持新克隆对象的状态
原型模式简化了创建结构
缺点:
实现深刻隆的时候需要比较复杂的代码
需要为每一个类配备一个克隆方法,对于全新的类不是很难,但对于已有类进行改造时候,不一定是容易的事情