原型模式的核型就是一个clone方法。 这也没什么好说的。 说道clone, 还是谈谈浅拷贝和深拷贝吧。
先看浅拷贝
浅拷贝只拷贝对象本身, 对于引用类型是不做拷贝的, 拷贝后的对象和被拷贝对象指向同一内存地址。
定义一个对象RMB
public class RMB implements Cloneable {
enum Type {
hard {
@Override
public String toString() {
return "硬币";
}
},
soft {
@Override
public String toString() {
return "纸币";
}
};
@Override
public abstract String toString();
}
private Type type;
private int value;
private String desc;
// useless, for testing purpose
private ArrayList<String> list = new ArrayList<String>();
// gets & sets
@Override
protected Object clone() {
RMB rmb = null;
try {
rmb = (RMB) super.clone();
} catch (CloneNotSupportedException e) {
// handle exception
e.printStackTrace();
}
return rmb;
}
}
然后进行拷贝
public class Client {
public static void main(String[] args) {
RMB myRMB = new RMB();
myRMB.setType(Type.soft);
myRMB.setValue(100);
myRMB.setDesc("有了这一张我就可以发达了, 哈哈哈");
myRMB.getList().add("value1");
myRMB.getList().add("value2");
RMB clonedRMB = (RMB) myRMB.clone();
clonedRMB.setType(Type.hard);
clonedRMB.getList().add("value3");
clonedRMB.setDesc("发达了");
System.out.println("被拷贝对象:");
System.out.println(myRMB.getType());
System.out.println(myRMB.getValue());
System.out.println(myRMB.getDesc());
Iterator iter = myRMB.getList().iterator();
while(iter.hasNext()){
System.out.println(iter.next());
}
System.out.println();
System.out.println("拷贝对象:");
System.out.println(clonedRMB.getType());
System.out.println(clonedRMB.getValue());
System.out.println(clonedRMB.getDesc());
Iterator clonedIter = clonedRMB.getList().iterator();
while(clonedIter.hasNext()){
System.out.println(clonedIter.next());
}
}
}
看看运行结果是怎样的
引用
被拷贝对象:
纸币
100
有了这一张我就可以发达了, 哈哈哈
value1
value2
value3
拷贝对象:
硬币
100
发达了
value1
value2
value3
可以看到, 拷贝对象的修改(引用类型)对被拷贝对象同样生效, 通常这不是我们所期望的。
那就来看看深度拷贝吧
对于本例的深度拷贝, 只需将RMB类进行小小的修改就可了
@Override
protected Object clone() {
RMB rmb = null;
try {
rmb = (RMB) super.clone();
[color=red]this.list = (ArrayList<String>) this.list.clone();[/color] } catch (CloneNotSupportedException e) {
// handle exception
e.printStackTrace();
}
return rmb;
}
现在看看结果:
引用
纸币
100
有了这一张我就可以发达了, 哈哈哈
value1
value2
拷贝对象:
硬币
100
发达了
value1
value2
value3
恩, 对了。。。
对于clone远不止这些, 以后再慢慢来整理, 急个毛。。。
分享到:
相关推荐
原型模式是设计模式中的一种,它是Java 23种经典设计模式之一,主要用来提高对象创建的效率。在原型模式中,我们通过复制或克隆一个已经存在的对象来创建新的对象,而不是通过构造函数来创建。这种方法尤其适用于当...
原型模式(Prototype Pattern)是软件设计模式中的一种结构型模式,它的主要目的是通过复制已有对象来创建新对象,从而减少创建新对象的成本。在原型模式中,类的实例化过程被替换为对已有实例的克隆操作,尤其适用...
原型模式(Prototype Pattern)是其中一种行为设计模式,主要用于对象创建。它通过复制已有对象来创建新对象,而不是通过传统的构造函数来创建。在Java中,原型模式可以有效地提高性能,特别是在创建复杂对象时。 #...
原型模式(Prototype Pattern)是一种创建型设计模式,它允许我们通过复制现有的对象来创建新对象,而无需知道具体创建过程的细节。这种模式的核心在于,它提供了一种对象克隆的简便方法,使得对象的创建过程对用户...
原型模式是一种创建型设计模式,它提供了一种创建对象的最佳方式。在原型模式中,一个对象可以被克隆以创建新对象,而无需知道具体的创建细节。这种模式在需要重复创建相似对象时非常有用,避免了每次创建新对象时都...
本篇文章将深入探讨“原型模式(Prototype)”这一经典的设计模式,它是面向对象设计的一个重要概念,尤其在C++编程中有着广泛的应用。 原型模式是一种创建型设计模式,它的核心思想是通过复制已有对象来创建新对象,...
原型模式(Prototype Pattern)是其中一种行为设计模式,它允许我们通过复制现有对象来创建新对象,而不是通过传统方式实例化新对象。这一模式尤其适用于创建复杂或昂贵的对象,因为它提供了对象克隆的能力,从而...
### Java设计模式之原型模式深度解析 #### 模式动机 在面向对象编程的世界里,对象的创建往往伴随着复杂的逻辑处理。特别是在某些场景下,对象的构造过程可能涉及大量资源的消耗,例如数据库连接、文件读写等。在...
基于Java实现的23种设计模式Demo,抽象工厂模式、建造模式、工厂方法模式、原型模式、单例模式、外观模式、适配器模式等 Java设计模式共有23种,分别为:抽象工厂模式、建造模式、工厂方法模式、原型模式、单例模式...
java设计模式【之】原型模式、深拷贝与浅拷贝【源码】【场景:克隆羊】 * 原型模式(Prototype) * 实现方式: * 需要被克隆的 class类, 重写Object中的clone()方法,并实现Cloneable接口(否则报错 ...
ava常用设计模式-原型模式 原型模式(Prototype Pattern)是一种创建型设计模式,允许通过复制现有对象来创建新对象,而不是通过实例化类来创建新对象。在需要创建大量相似对象时非常有用,它可以避免重复创建对象...
【设计模式之原型模式】 设计模式是软件工程中的一种最佳实践,是对在特定上下文中反复出现的软件设计问题的解决方案。原型模式属于对象创建型模式,它的主要思想是通过复制已有对象来创建新对象,降低了类的实例化...
设计模式 的分类 总体来说设计模式分为三大类: 创建型模式(5): 工厂方法模式 、抽象工厂模式、单例模式、建造者模式、原型模式。 结构型模式(7): 适配器模式、装饰器模式、代理模式、外观模式、桥接模式、...
C#23种设计模式样例代码和UML图等 创建型模式(抽象工厂模式、工厂方法模式、单例模式、建造者模式、原型模式); 行为型模式(策略模式、 迭代器模式、原型模式、职责链模式、 模板方法、 命令模式、 解释器模式、 ...
JDK中许多类和方法都使用了设计模式,这些模式的应用帮助实现了代码的高内聚、低耦合,提高了代码的可维护性和扩展性。下面介绍几种常见的设计模式及其在JDK中的应用实例: a) 抽象工厂模式(AbstractFactory) ...
本资料集包含了多种重要的前端设计模式,如工厂模式、原型模式和构造器模式,下面将详细阐述这些模式的核心概念和应用。 1. 工厂模式: 工厂模式是一种创建型设计模式,它提供了一种创建对象的最佳方式,通过抽象出...