原型设计模式

1、实现 

原型模式的克隆分为浅克隆和深克隆。

浅克隆:创建一个新对象,新对象的属性和原来对象完全相同,对于非基本类型属性,仍指向原有属性所指向的对象的内存地址。

深克隆:创建一个新对象,属性中引用的其他对象也会被克隆,不再指向原有对象地址。

Java中的Object类中提供了clone()方法 来实现浅克隆。Cloneable接口上面的类图中的抽象原型类,而实现了Cloneable接口的子实现类就是具体的原型类

package com.jmj.pattern.prototype.demo;

public class Realizetype implements Cloneable{

    public Realizetype() {
        System.out.println("具体的原型对象创建完成!");
    }

    @Override
    protected Realizetype clone() throws CloneNotSupportedException {
        System.out.println("具体原型复制成功!");
        return (Realizetype)super.clone();
    }
}
package com.jmj.pattern.prototype.demo;

public class Client {
    public static void main(String[] args) throws CloneNotSupportedException {
        Realizetype realizetype = new Realizetype();
        System.out.println(realizetype);

        //没有再次执行无参构造
        Realizetype clone = realizetype.clone();
        System.out.println(clone);
    }
}

package com.jmj.pattern.prototype.test;

import java.io.FilterOutputStream;

public class Citation implements Cloneable{


    //三好学生上的姓名
    private String name;

    public String getName() {
        return name;
    }

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

    public void show(){
        System.out.println(name+"同学:在2020学年第一学期中表现优秀,被评为三好学生。特发此状!");
    }

    @Override
    public Citation clone() throws CloneNotSupportedException {
        return (Citation) super.clone();
    }
}
package com.jmj.pattern.prototype.test;

public class CitationTest {
    public static void main(String[] args) throws CloneNotSupportedException {
        //1.创建原型对象
        Citation citation = new Citation();
        Citation clone = citation.clone();
        clone.setName("张三");
        citation.setName("李四");

        citation.show();
        clone.show();
    }
}

package com.jmj.pattern.prototype.test11;

import java.io.*;

public class CitationTest {
    public static void main(String[] args) throws CloneNotSupportedException, IOException, ClassNotFoundException {
        //1.创建原型对象
        Citation citation = new Citation();
        Student student = new Student();
        student.setName("张三");
        citation.setStudent(student);


        ObjectOutputStream oos =new ObjectOutputStream(new FileOutputStream("src/main/resources/static/b.txt"));

        oos.writeObject(citation);
        oos.close();

        ObjectInputStream ois=new ObjectInputStream(new FileInputStream("src/main/resources/static/b.txt"));
        Citation o = (Citation) ois.readObject();

        ois.close();

        o.getStudent().setName("李四");

        citation.show();
        o.show();

    }
}

 总结:浅克隆 实现Cloneable接口 重写clone方法 。       

          深克隆  用序列化和反序列化实现深克隆。


                
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
非常感谢您的提问!以下是一个使用原型设计模式实现深拷贝的示例代码: ``` class Prototype { public: virtual Prototype* clone() = 0; }; class ConcretePrototype : public Prototype { public: ConcretePrototype(int value) : m_value(value) {} Prototype* clone() override { return new ConcretePrototype(m_value); } int getValue() const { return m_value; } private: int m_value; }; int main() { ConcretePrototype* original = new ConcretePrototype(42); ConcretePrototype* clone = dynamic_cast<ConcretePrototype*>(original->clone()); std::cout << "Original value: " << original->getValue() << std::endl; std::cout << "Clone value: " << clone->getValue() << std::endl; delete original; delete clone; return 0; } ``` 在这个示例中,我们定义了一个 `Prototype` 接口,其中包含了一个 `clone()` 方法,用于创建一个与原型对象相同的新对象。然后,我们实现了一个具体的原型类 `ConcretePrototype`,其中包含了一个整型成员变量 `m_value`,并重写了 `clone()` 方法,返回一个新的 `ConcretePrototype` 对象。最后,我们在 `main()` 函数中创建了一个原型对象 `original`,并通过调用 `clone()` 方法创建了一个新的克隆对象 `clone`。 需要注意的是,这里的深拷贝只是一个简单的示例,实际上在实现深拷贝时需要考虑对象的所有成员变量,并递归地进行拷贝。此外,还需要注意内存管理,确保在不需要使用对象时及时释放内存。 希望这个示例能够帮助您理解原型设计模式和深拷贝的实现方式。如果您有任何问题或需要进一步的帮助,请随时提出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值