原型模式

本文介绍原型模式的概念及其实现方式,包括浅拷贝与深拷贝的区别,并通过示例代码展示了如何在Java中使用原型模式来提高对象创建的效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

定义

原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象,不需要知道任何创建的细节,不调用构造函数

适用场景

  • 类初始化消耗较多资源
  • new产生的一个对象需要非常繁琐的过程(数据准备、访问权限等)
  • 构造函数比较复杂
  • 循环体中生产大量对象

优点

  • 原型模式性能比直接new一个对象性能高
  • 简化创建过程

缺点

  • 必须配备克隆方法
  • 对克隆复杂对象或对克隆出的对象进行复杂构造时,容易引入风险
  • 深拷贝、浅拷贝要运用得当

浅拷贝

//原型模式实现Cloneable接口
public class Pig implements Cloneable {
    public String name;
    public Date birthday;

    public Pig(String name, Date birthday) {
        this.name = name;
        this.birthday = birthday;
    }
    @Override
    protected Pig clone() throws CloneNotSupportedException {
        return (Pig) super.clone();
    }
}

public class Test {
    public static void main(String[] args) throws Exception {
        //实例化一个小猪1
        Pig pig1 = new Pig("佩奇",new Date(0L));
        System.out.println(pig1.birthday);
        //拷贝生成一个小猪2
        Pig pig2 = pig1.clone();
        //更改小猪1的生日
        pig1.birthday.setTime(999999999999L);
        //小猪2的生日也随之更改了
        System.out.println(pig2.birthday);
    }
}

原型模式默认浅克隆,虽然pig1和pig2是两个不同的对象,但是内部成员变量Date(引用类型)则是指向的同一个对象。所以更改了pig1的生日,pig2的生日也随之变化了。

深克隆

public class Pig implements Cloneable {
    public String name;
    public Date birthday;

    public Pig(String name, Date birthday) {
        this.name = name;
        this.birthday = birthday;
    }
    @Override
    protected Pig clone() throws CloneNotSupportedException {
        Pig pig = (Pig) super.clone();
        //深克隆
        pig.birthday = (Date) pig.birthday.clone();
        return pig;
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值