为了账号安全,请及时绑定邮箱和手机立即绑定

设计模式之--原型模式

标签:
设计

1.原型模式定义

原型模式非常简单,定义如下:

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

2.通用类图

原型模式的核心是实现Cloneable接口,此接口为JDK提供的一个标识接口,只有实现了此接口的类才能被拷贝。
原型模式的通用类图如下;
https://img1.sycdn.imooc.com//5b89ffbb0001c60215861010.jpg

3.通用原型实现代码

原型类:

public class ConcretePrototype implements Cloneable {    private int id;    private String name;    public ConcretePrototype() {
        System.out.println("ConcretePrototype construct.");
    }    public int getId() {        return id;
    }    public void setId(int id) {        this.id = id;
    }    public String getName() {        return name;
    }    public void setName(String name) {        this.name = name;
    }    @Override
    protected Object clone() throws CloneNotSupportedException {
        ConcretePrototype concretePrototype = null;        try {
            concretePrototype = (ConcretePrototype) super.clone();
        } catch (Exception e) {

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

Client测试代码:

public class Client {    public static void main(String[] args) throws Exception {
        ConcretePrototype concretePrototype = new ConcretePrototype();
        concretePrototype.setId(123);
        concretePrototype.setName("test");

        ConcretePrototype cloneType = (ConcretePrototype) concretePrototype.clone();
        cloneType.setId(111);
        cloneType.setName("test111");
        System.out.println(concretePrototype);
        System.out.println(cloneType);
    }
}

输出结果如下:

ConcretePrototype construct.ConcretePrototype{id=123, name='test'}ConcretePrototype{id=111, name='test111'}

通过输出结果可以看出,通过clone方法拷贝了一个新的对象。

4.原型模式的优点

1.性能优良
原型模式是在内存中二进制流的拷贝,要比直接new一个对象快的多

2.通过3中的输出结果来看,在clone对象的时候构造函数不会执行,这对于一些需要在构造函数中做一些初始化的类来说可能称为约束

5.需要注意的点

在原型模式拷贝的时候需要注意可变引用类型的属性,下面通过一个例子来说明此问题:
拷贝对象:

public class DeepClone implements Cloneable{    private Map<String, Object> map = new HashMap<>();    public void addPair(String key, String value){
        map.put(key, value);
    }    public Map<String , Object> getMap(){        return map;
    }

    @Override    protected Object clone() throws CloneNotSupportedException {
        DeepClone  deepClone = null;        try {
            deepClone = (DeepClone) super.clone();
        } catch (Exception e) {

        }        return deepClone;
    }
}

Client类

public class Client {    public static void main(String[] args) throws Exception {
        DeepClone deepClone = new DeepClone();
        deepClone.addPair("key1", "value1");

        DeepClone clone = (DeepClone) deepClone.clone();        clone.addPair("key2", "value2");
        System.out.println(deepClone.getMap());

    }


}

输出结果如下:

{key1=value1, key2=value2}

在使用clone方法拷贝对象的时候引用类型的属性不会继续做拷贝,而是多个拷贝对象使用同一个属性,这种被称为浅拷贝。
下面对clone方法重写完成深拷贝:

@Override
protected Object clone() throws CloneNotSupportedException {
    DeepClone  deepClone = null;    try {
        deepClone = (DeepClone) super.clone();        Map<String, Object> cloneMap = new HashMap<>();
        cloneMap.putAll(this.map);

        deepClone.map = cloneMap;
    } catch (Exception e) {

    }    return deepClone;
}

重新执行client输出结果为:

{key1=value1}

原文出处:https://www.cnblogs.com/vitasyuan/p/9569404.html

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消