演示原型模式的实现方法:
代码语言:javascript复制// 原型接口
public interface Prototype {
Prototype clone();
}
// 具体的学生类,实现原型接口并重写复制方法
public class Student implements Prototype {
private String name;
private int age;
public Student(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
// 实现 clone() 方法,返回一个新的学生对象并复制原有对象的属性
@Override
public Prototype clone() {
return new Student(name, age);
}
}
// 客户端代码
public class Client {
public static void main(String[] args) {
// 创建原型对象
Student stu1 = new Student("张三", 20);
// 克隆新对象并修改属性
Student stu2 = (Student) stu1.clone();
stu2.setName("李四");
stu2.setAge(21);
// 打印结果
System.out.println("stu1: " stu1.getName() ", " stu1.getAge());
System.out.println("stu2: " stu2.getName() ", " stu2.getAge());
}
}
在这个示例代码中,我们定义了一个原型接口 Prototype 和一个具体的学生类 Student,该类实现了原型接口并重写了 clone() 方法。在客户端代码中,我们创建了一个原型对象 stu1,并通过克隆原型对象来生成一个新的学生对象 stu2,然后修改 stu2 对象的属性并打印结果。由于 stu1 和 stu2 对象是互相独立的,因此修改 stu2 的属性不会影响 stu1 对象的属性。
需要注意的是,在实现原型模式时,要确保克隆对象的深浅复制问题。在示例代码中,我们只需要对基本类型的成员变量进行复制,因此可以使用浅复制来实现 clone() 方法。但如果 Student 类中包含了非基本类型的成员变量,例如一个引用类型的属性 Address,那么就需要对这个属性进行深度克隆,否则复制出来的新对象和原有对象会共享这个引用类型的属性,可能会引发潜在的问题。
因此,在实现原型模式时,需要根据具体的场景选择适当的复制方法来确保克隆对象的正确性。如果对象比较简单,只包含基本类型的成员变量,可以使用浅复制来实现 clone() 方法;如果对象比较复杂,包含了多个引用类型的成员变量,就需要使用深复制来确保新对象和原有对象的属性是完全独立的。