浅谈原型模式(Prototype Pattern)

原型模式

原型模式非常好理解和简单,所以在很多场景中也经常使用,其定义如下:

用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象

通俗的讲就是不使用new方法来生成一个新的对象,来实现对象的实例化操作。

模式组成

在这里插入图片描述

这个类图非常简单,其核型就是一个clone()方法,通过该方法完成对对象的拷贝,在java中提供一个Cloneable接口来标示这个对象是可拷贝的,这个接口没有方法,只是其起一个标记作用,在JVM中具有这个标记的对象有可能被拷贝。

import java.util.ArrayList;

public class PrototypeClass implements Cloneable {

	private ArrayList<String> list = new ArrayList<String>();

	public PrototypeClass() {
		// TODO Auto-generated constructor stub
		System.out.println("构造函数被执行。。。");
	}
	public PrototypeClass clone() {
		PrototypeClass pro = null;
		try {
			pro = (PrototypeClass)super.clone();
			this.list = (ArrayList<String>)this.list.clone(); //深拷贝
		} catch(Exception e) {
			System.out.println(e);
		}
		return pro;
	}

	public void setValue(String value) {
		this.list.add(value);
	}

	public ArrayList<String> getValue() {
		return this.list;
	}
}

测试类:

public class Client {

	public static void main(String[] args) {
		PrototypeClass pro = new PrototypeClass();
		pro.setValue("张三");
		PrototypeClass pro2 = pro.clone();
		pro2.setValue("李四");
		System.out.println(pro.getValue());
	}
}

原型模式的总结

  • 性能优良:原型模式是在内存二进制流的拷贝,比直接new的性能要高
  • 逃避构造函数的约束:直接在内存中拷贝,构造函数不会执行

使用场景

  • 资源优化场景
  • 性能和安全要求场景
  • 一个对象多个修改者的场景

注意事项

  • 构造函数不会执行
  • 浅拷贝和深拷贝问题
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值