设计模式之原型模式

本文深入探讨了Java中的原型模式,这是一种用于对象克隆和深拷贝的技术,旨在减少初始化代码并保持对象间的独立性。示例展示了如何通过实现Cloneable接口和重写clone方法实现对象的复制。此外,还提到了使用序列化实现对象拷贝的方法。原型模式适用于代码不依赖具体类克隆对象的情况,具有降低耦合度和简化复杂数据结构构建等优点。
摘要由CSDN通过智能技术生成

原型模式实例

原型模式主要用于对一个对象的克隆以及深拷贝,使对象所有属性进行复制的同时并不会造成相同地址的引用。

首先可以实现Cloneable接口使对象可以实现克隆。再通过重写父类的clone方法来实现对象的克隆,如出现对象嵌套操作的话则需要实现深拷贝。

public class PrototypeTest {
    public static void main(String[] args) throws CloneNotSupportedException {
        BaseInfo baseInfo = new BaseInfo("XXX");
        Product product = new Product("part1", "part2", "part3",baseInfo);

        Product clone = product.clone();
        System.out.println(product);
        System.out.println(clone);

        product.getBaseInfo().setCompanyName("YYY");
        System.out.println(product);
        System.out.println(clone);
    }
}

class BaseInfo implements Cloneable,Serializable{
    private String companyName;

    public String getCompanyName() {
        return companyName;
    }

    public void setCompanyName(String companyName) {
        this.companyName = companyName;
    }

    public BaseInfo(String companyName) {
        this.companyName = companyName;
    }

    @Override
    protected BaseInfo clone() throws CloneNotSupportedException {
        return (BaseInfo) super.clone();
    }

    @Override
    public String toString() {
        return super.hashCode()+"|BaseInfo{" +
                "companyName='" + companyName + '\'' +
                '}';
    }
}

class Product implements Cloneable,Serializable{
    private String part1;
    private String part2;
    private String part3;
    private BaseInfo baseInfo;


    public Product() {
    }

    public Product(String part1, String part2, String part3,BaseInfo baseInfo) {
        this.part1 = part1;
        this.part2 = part2;
        this.part3 = part3;
        this.baseInfo = baseInfo;
    }

    public BaseInfo getBaseInfo() {
        return baseInfo;
    }

    public void setBaseInfo(BaseInfo baseInfo) {
        this.baseInfo = baseInfo;
    }

    public String getPart1() {
        return part1;
    }

    public void setPart1(String part1) {
        this.part1 = part1;
    }

    public String getPart2() {
        return part2;
    }

    public void setPart2(String part2) {
        this.part2 = part2;
    }

    public String getPart3() {
        return part3;
    }

    public void setPart3(String part3) {
        this.part3 = part3;
    }

    @Override
    protected Product clone(){

        Product clone = (Product) super.clone();
        BaseInfo clone1 = this.baseInfo.clone();
        clone.setBaseInfo(clone1);
        return clone;
    }

    @Override
    public String toString() {
        return super.hashCode()+"|Product{" +
                "part1='" + part1 + '\'' +
                ", part2='" + part2 + '\'' +
                ", part3='" + part3 + '\'' +
                ", baseInfo=" + baseInfo +
                '}';
    }
}

也可以使用流的操作来实现对象的拷贝。

    @Override
    protected Product clone(){

        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
        try {
            ObjectOutputStream oos = new ObjectOutputStream(byteArrayOutputStream);
            oos.writeObject(this);
        } catch (IOException e) {
            e.printStackTrace();
        }
        ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());

        try {
            ObjectInputStream ois = new ObjectInputStream(byteArrayInputStream);
            Product object = ((Product) ois.readObject());
            return object;
        } catch (IOException | ClassNotFoundException e) {
            e.printStackTrace();
        }

        return null;
    }

应用场景

当代码不应该依赖于需要复制的对象的具体类时,需要使用原型模式。

优点

  1. 可以在不耦合具体类的情况下克隆对象。
  2. 避免重复的初始化代码。
  3. 更方便的构建复杂的数据结构。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值