设计模式之原型模式

一、介绍

原型模式属于创建型设计模式 ,用于创建重复 的对象,且同时又保证了性能

该设计模式的好处是将对象的创建与调用方分离

其目的就是** 根据一个对象(称为原型)创建一个与其完全相同的对象(当然内存地址不同) **原对象被认为是新对象的原型。

二、实现步骤

原型模式的实现步骤如下:

  • 应用原型模式的类要实现Cloneable接口。
  • 应用原型模式的类要重写Object类定义的clone()方法。
  • 通过调用对象的clone()方法,获得一个与该对象相同的对象。

在重写Object类定义的clone()方法时,直接通过调用super.clone()即可得到一个新对象,如下所示

三、案例

浅拷贝 :复制对象及基本数据类型,引用类型的字段共享原对象得到内存地址。

java 复制代码
public class Person implements Cloneable {
    private String name;
    private Integer age;
    private String sex;
    private List<String> friends = new ArrayList<>();

    public void addFriends(String friends)  {
        this.friends.add(friends);
    }

    @Override
    public Person clone() {
        try {
            Person person = (Person) super.clone(); // 浅拷贝,items引用共享
            return person;
        } catch (CloneNotSupportedException e) {
            throw new AssertionError();
        }
    }

    public String getName() {
        return name;
    }

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

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getSex() {
        return sex;
    }
    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", sex='" + sex + '\'' +
                ", friends=" + friends +
                '}';
    }


    public void setSex(String sex) {
        this.sex = sex;
    }

}

测试:

深拷贝:递归复制所有引用对象,确保数据独立性。

java 复制代码
public class Person2 implements Cloneable {
    private String name;
    private Integer age;
    private String sex;
    private List<String> friends = new ArrayList<>();

    public void addFriends(String friends)  {
        this.friends.add(friends);
    }

    @Override
    public Person2 clone() {
        try {
            Person2 copy = (Person2) super.clone();
            copy.friends = new ArrayList<>(this.friends); // 手动复制列表元素
            return copy;
        } catch (CloneNotSupportedException e) {
            throw new AssertionError();
        }
    }

    public String getName() {
        return name;
    }

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

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getSex() {
        return sex;
    }
    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", sex='" + sex + '\'' +
                ", friends=" + friends +
                '}';
    }


    public void setSex(String sex) {
        this.sex = sex;
    }

}

测试:

四、应用场景

  • 资源消耗大对象:如数据库连接配置,避免重复初始化。
  • 动态状态保存:游戏存档、文档历史版本。
  • 复杂对象生成:GUI控件、多层级配置对象。

七、总结

  • 原型模式用于创建具有相同属性的重复对象。
  • 原型模式的实现就是实现Cloneable接口 + 重写clone()方法实现的。
  • Object类的clone()方法实现由JVM实现,性能较好。但仅能实现浅拷贝
复制代码
相关推荐
workflower5 小时前
使用大语言模型处理用户需求
大数据·人工智能·设计模式·重构·动态规划
geovindu10 小时前
go: Generators Pattern
开发语言·后端·设计模式·golang·生成器模式
GuWenyue13 小时前
前端异步请求踩坑?3种方式搞定Ajax数据交互,从XHR到async/await
前端·javascript·设计模式
我登哥MVP15 小时前
走进 Gang of Four 设计模式:装饰器模式
java·spring boot·设计模式·装饰器模式
秋漓17 小时前
软件设计模式
设计模式
许彰午17 小时前
36_Java设计模式之代理模式
java·设计模式·代理模式
许彰午17 小时前
35_Java设计模式之工厂模式
java·开发语言·设计模式
uoKent17 小时前
项目整理——设计模式
设计模式·软件需求
折哥的程序人生 · 物流技术专研18 小时前
Java 23 种设计模式:从踩坑到精通 | 番外:编排器+策略模式在多平台电子面单中的实战(含性能压测)
设计模式·策略模式·代码重构·java设计模式·编排器·电子面单·从踩坑到精通
YXLY25281 天前
庭院大门选型方案:铝艺大门的五大设计模式与六大性能优势分析
设计模式