java中的clone

clone构造器及其静态工厂的变形

优点:它们不依赖于某一种很有风险的,语言之外的对象创建机制;

它们不要求遵守尚未制定好文档的规范

他们不会于final域的正常使用发生冲突

它们不会抛出不必要的受检异常

它们不需要进行类型转换

/**

* 1.必须继承Cloneable接口

* 2.必须重写Object类中的clone()方法 –

* Cloneable接口改变了接口的通用规范,它改变了超类中受保护的方法的行为

* –无需构造器就可以创建对象

* a.clone对象分配有独立的内存地址 – x.clone()!=x;

* b.原始的克隆对象应该具有相同类型 x.clone().getClass == x.getClass 非必需

* c.原始的克隆对象调用equals方法的话,应该是相等的 非必需

* @author JacXuan

*

*/

public class Father implements Cloneable{
private int age;
private String name;
private Son son; public Father(int age,String name,Son son){
this.age = age;
this.name = name;
this.son = son;
} public Son getSon(){
return this.son;
}
public void setSon(Son son){
this.son = son;
}
/**
* 浅拷贝代码--
* 原始对象和克隆对象拥有指向同一对象的两个引用,所以可以通过改变cloneFather
* 中的Son来改变father中的Son对象
* @throws CloneNotSupportedException
*/
// @Override
// public Object clone() throws CloneNotSupportedException{
// return super.clone();
// } /**
* 深拷贝 -- 在Son中实现clone方法 return super.clone();
*/
@Override
public Object clone() throws CloneNotSupportedException{
Father father = (Father)super.clone();
father.setSon((Son)father.getSon().clone());
return father;
}
} Son son = new Son(20, "PG");
Father father = new Father(40, "JacX", son); Father cloneFather = (Father)father.clone();
System.out.println(father!=cloneFather);
System.out.println(cloneFather.getClass() == father.getClass());
System.out.println(cloneFather.equals(father)); 2.package com.object.equals.clone.conctr; /**
* 拷贝构造函数 -- 一种特殊的构造器
* 它将自己的类类型作为参数 传递一个类的实例给拷贝构造函数,
* 然后他将返回一个新的类实例
* @author JacXuan
*
*/
public class CloneConctr {
private Integer x;
private Integer y; public CloneConctr(CloneConctr cloneConctr){
this.x = cloneConctr.x;
this.y=cloneConctr.y;
} // public CloneConctr copyPoint(CloneConctr cloneConctr) throws CloneNotSupportedException{
// if(!(cloneConctr instanceof Cloneable)){
// throw new CloneNotSupportedException("Invalid clone");
// }
//
// //可以做多种其他事情
// return new CloneConctr(cloneConctr.x,cloneConctr.y);
// } /**
* 最佳实践
*1)当你不知道你是否可以调用clone()方法的类你不确定如果是在这个类中实现,
*您可以检查和检查如果类的实例“可克隆”界面如下。
*/
// if(obj instanceof Cloneable){
//obj2 = obj.clone();
//}
//Dont do this. Cloneabe dont have any methods
//obj2 = obj.clone();
} package com.object.equals.clone.conctr; /**
* 如果要继承它的话,则需要复制子类的参数并传递参数给父类的构造器
* @author JacXuan
*
*/
public class CloneConctr2 extends CloneConctr{
private Integer z; public CloneConctr2(CloneConctr2 cloneConctr2){
super(cloneConctr2);
this.z = cloneConctr2.z;
}
} 3.package com.object.equals.clone.hashtable; /**
* 解决克隆对象和原有对象引用链表相同引起的数据篡改 单独地拷贝并组成每个桶的链表
* 如果链表比较长,容易导致栈溢出
* @author JacXuan
*
*/
public class HashTable implements Cloneable {
private Entry[] buckets = null; private static class Entry {
final Object key;
Object value;
Entry next; Entry(Object key, Object value, Entry next) {
this.key = key;
this.value = value;
this.next = next;
} Entry deepCopy() {
//深度克隆 如果桶是空的,则clone下一个
return new Entry(key, value, next == null ? null : next.deepCopy());
}
} @Override
public HashTable clone() throws CloneNotSupportedException {
HashTable result = (HashTable) super.clone();
result.buckets = new Entry[buckets.length];
for (int i = 0; i < buckets.length; i++) {
if (buckets[i] != null) {
result.buckets[i] = buckets[i].deepCopy();
}
}
return result;
} }

EffectiveJava(11)Java中的clone的更多相关文章

  1. 深入理解Java中的Clone与深拷贝和浅拷贝

    1.Java对象的创建 clone顾名思义就是复制, 在Java语言中, clone方法被对象调用,所以会复制对象.所谓的复制对象,首先要分配一个和源对象同样大小的空间,在这个空间中创建一个新的对象. ...

  2. 详解Java中的clone方法

    详解Java中的clone方法 参考:http://blog.csdn.net/zhangjg_blog/article/details/18369201/ 所谓的复制对象,首先要分配一个和源对象同样 ...

  3. 浅拷贝和深拷贝(谈谈java中的clone)

    clone顾名思义就是复制, 在Java语言中, clone方法被对象调用,所以会复制对象.所谓的复制对象,首先要分配一个和源对象同样大小的空间,在这个空间中创建一个新的对象.那么在java语言中,有 ...

  4. Java中对Clone的理解

    面试中经常遇到Clone的相关知识,今天总算是把Clone理解的比较透彻了!Java中Clone的概念大家应该都很熟悉了,它可以让我们很方便的“制造”出一个对象的副本来,下面来具体看看java中的Cl ...

  5. 【转】java中的clone

    java中的clone Clone&Copy 假设现在有一个Employee对象,Employee tobby =new Employee("CMTobby",5000), ...

  6. JAVA中的clone方法剖析

    原文出自:http://blog.csdn.net/shootyou/article/details/3945221 java中也有这么一个概念,它可以让我们很方便的"制造"出一个 ...

  7. Java中的clone()----深复制,浅复制

    这篇文章主要介绍了Java中对象的深复制(深克隆)和浅复制(浅克隆) ,需要的朋友可以参考下 1.浅复制与深复制概念 ⑴浅复制(浅克隆) 被复制对象的所有变量都含有与原来的对象相同的值,而所有的对其他 ...

  8. 详解Java中的clone方法:原型模式

    转:http://developer.51cto.com/art/201506/478985.htm clone顾名思义就是复制, 在Java语言中, clone方法被对象调用,所以会复制对象.所谓的 ...

  9. 转:Java中的Clone()方法详解

    Java中对象的创建 clone顾名思义就是复制, 在Java语言中, clone方法被对象调用,所以会复制对象.所谓的复制对象,首先要分配一个和源对象同样大小的空间,在这个空间中创建一个新的对象.那 ...

随机推荐

  1. float存储

    浮点型变量在计算机内存中占用4字节(Byte),即32-bit.遵循IEEE-754格式标准. 一个浮点数由2部分组成:底数m 和 指数e.                          ±man ...

  2. 记录string的妙用

    P1106 删数问题 摘要 --> 题目描述 键盘输入一个高精度的正整数N,去掉其中任意k个数字后剩下的数字按原左右次序将组成一个新的正整数.编程对给定的N和k,寻找一种方案使得剩下的数字组成的 ...

  3. 关于each()、find()、filter()遍历节点的操作方法

    关于each().find().filter()遍历节点的操作方法 each语法: each(fn)  ; 返回值:jQuery fn:代表对于每个匹配元素所要执行的函数 each()方法共有三种形式 ...

  4. UVA 10652 Board Wrapping(二维凸包)

    传送门 刘汝佳<算法竞赛入门经典>P272例题6包装木板 题意:有n块矩形木板,你的任务是用一个面积尽量小的凸多边形把它们抱起来,并计算出木板占整个包装面积的百分比. 输入:t组数据,每组 ...

  5. error LNK2001: 无法解析的外部符号 "public: virtual long __stdcall CBaseFilter(转)

    原文转自 https://www.cnblogs.com/xiongjiaji/archive/2010/12/31/2476565.html 今天用VS2005编译DirectShow程序,发现出来 ...

  6. 【友盟统计报表解读】之错误分析iOS版

    http://bbs.umeng.com/thread-6908-1-1.html 错误分析功能说明1.概述 错误分析是友盟为移动开发者提供的Crash收集和分析工具,帮助开发者监测App在移动设备上 ...

  7. kvm虚拟机最佳实践系列1-kvm宿主机准备

    KVM宿主机配置 系统环境:ubuntu16, bond0 业务网口 bond1 管理网口+存储网口 安装KVM环境支持 sudo apt-get install qemu-kvm sudo apt- ...

  8. android的百度地图开发(二) 定位

    参考:http://blog.csdn.net/mr_wzc/article/details/51590485 第一步,初始化LocationClient类 //获取地图控件引用 mMapView = ...

  9. POJ 3468.A Simple Problem with Integers-线段树(成段增减、区间查询求和)

    POJ 3468.A Simple Problem with Integers 这个题就是成段的增减以及区间查询求和操作. 代码: #include<iostream> #include& ...

  10. Peak

    A sequence of \(n\) integers \(a_1, a_2, \dots, a_n\) is called a peak, if and only if there exists ...