原型模式(Prototype Pattern)

原型模式(Prototype Pattern)

原型模式是一种 创建型设计模式 ,通过复制现有的实例来创建新的对象,而不是通过实例化(new)来创建,从而提高性能。


原理

  1. 核心思想:提供一个现有对象的模板,通过克隆来创建新的对象。
  2. 适用场景:当对象的创建成本较高,且需要多个类似的对象时,使用原型模式可以提高效率。
  3. 参与角色
    • Prototype(原型接口) :定义克隆方法(通常为 clone())。
    • ConcretePrototype(具体原型类):实现克隆方法,负责实际对象的复制。
    • Client(客户端):通过调用克隆方法创建对象。

优点

  1. 性能高效:通过克隆对象避免了复杂的对象创建过程。
  2. 动态性强:可以在运行时动态创建对象,而不需要依赖具体类。
  3. 灵活性:对于复杂对象可以深拷贝,从而实现完全独立的复制。

缺点

  1. 实现复杂:需要实现深拷贝时,可能会引入额外的复杂性。
  2. 资源消耗:对于深拷贝,克隆过程可能涉及大量的递归或额外的代码。

示例代码

1. 定义原型接口
java 复制代码
// 定义原型接口
public interface Prototype extends Cloneable {
    Prototype clone();
}

2. 具体原型类
java 复制代码
// 具体原型类
public class ConcretePrototype implements Prototype {
    private String name;

    public ConcretePrototype(String name) {
        this.name = name;
    }

    // 实现克隆方法
    @Override
    public Prototype clone() {
        try {
            return (Prototype) super.clone(); // 浅拷贝
        } catch (CloneNotSupportedException e) {
            throw new RuntimeException("Clone not supported", e);
        }
    }

    // Getter 和 Setter
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return "ConcretePrototype{name='" + name + "'}";
    }
}

3. 客户端代码
java 复制代码
public class PrototypeExample {
    public static void main(String[] args) {
        // 创建一个原型对象
        ConcretePrototype prototype = new ConcretePrototype("Original");

        // 克隆对象
        ConcretePrototype clone1 = (ConcretePrototype) prototype.clone();
        ConcretePrototype clone2 = (ConcretePrototype) prototype.clone();

        // 修改克隆对象
        clone1.setName("Clone 1");
        clone2.setName("Clone 2");

        // 打印结果
        System.out.println("Original: " + prototype);
        System.out.println("Clone 1: " + clone1);
        System.out.println("Clone 2: " + clone2);
    }
}

输出结果
text 复制代码
Original: ConcretePrototype{name='Original'}
Clone 1: ConcretePrototype{name='Clone 1'}
Clone 2: ConcretePrototype{name='Clone 2'}

深拷贝和浅拷贝

  • 浅拷贝
    • 复制对象时,只复制基本类型字段。
    • 对于引用类型字段,只复制引用地址(共享同一个引用对象)。
java 复制代码
@Override
public Prototype clone() {
    try {
        return (Prototype) super.clone(); // 默认浅拷贝
    } catch (CloneNotSupportedException e) {
        throw new RuntimeException("Clone not supported", e);
    }
}
  • 深拷贝
    • 复制对象时,除了基本类型字段,还需要递归复制引用类型字段,确保拷贝对象完全独立。
java 复制代码
@Override
public Prototype clone() {
    try {
        ConcretePrototype cloned = (ConcretePrototype) super.clone();
        cloned.setReference(new Reference(this.reference.getValue())); // 手动深拷贝
        return cloned;
    } catch (CloneNotSupportedException e) {
        throw new RuntimeException("Clone not supported", e);
    }
}

使用场景

  1. 对象创建开销大
    • 数据库连接对象、线程池对象。
  2. 重复对象相似度高
    • 图形界面中的按钮、表单等 UI 元素。
  3. 需要动态创建类的实例
    • 在运行时动态加载并复制类。

UML 类图

复制代码
        +-------------------+
        |    Prototype      |
        +-------------------+
        |  + clone()        |
        +-------------------+
                ^
                |
        +-------------------+
        | ConcretePrototype |
        +-------------------+
        |  - name           |
        |  + clone()        |
        +-------------------+
                ^
                |
        +-------------------+
        |     Client        |
        +-------------------+

小结

  • 原型模式通过克隆对象来避免复杂对象的直接创建过程,提高了代码的灵活性和性能。
  • 使用时需特别注意 深拷贝浅拷贝 的实现,尤其是对象中包含引用类型时。
相关推荐
魔云连洲4 小时前
深入解析:Object.prototype.toString.call() 的工作原理与实战应用
前端·javascript·原型模式
white-persist2 天前
Burp Suite模拟器抓包全攻略
前端·网络·安全·web安全·notepad++·原型模式
青草地溪水旁2 天前
第五章:原型模式 - 克隆大法的大师
c++·设计模式·原型模式
white-persist2 天前
【burp手机真机抓包】Burp Suite 在真机(Android and IOS)抓包手机APP + 微信小程序详细教程
android·前端·ios·智能手机·微信小程序·小程序·原型模式
XiaoLeisj6 天前
【SpringAI】第四弹:深入解析 Rag 检索增强工作流程、最佳实践和调优
阿里云·原型模式·rag·spring ai·灵积大模型
CoderIsArt7 天前
四种对象型创建模式:抽象工厂、 build模式、原型ProtoType与单例模式
单例模式·原型模式
Misnearch8 天前
原型模式了解
原型模式
charlie11451419110 天前
精读《C++20设计模式》——创造型设计模式:原型模式
设计模式·程序设计·原型模式·c++20
Mr_WangAndy12 天前
C++设计模式_创建型模式_原型模式Prototype
c++·设计模式·原型模式
奔跑吧邓邓子12 天前
【C++实战㊷】C++ 原型模式实战:从概念到高效应用
c++·实战·原型模式