java深拷贝和浅拷贝_java数组copyof

java深拷贝和浅拷贝_java数组copyof实现拷贝有几点:1)实现Cloneable接口2)重写Object类中的clone方法,并将可见性从protect改为public3)克隆需要调用super.clone(),也就是Object的实现方法浅拷贝和深拷贝的区别:浅拷贝是指拷贝对象时仅仅拷贝对象本身(包括对象中的基本变量),而不拷贝对象包含的引用指向的对象。深拷贝不仅拷贝对象本身,而且拷贝对象包含的引用指向的所有对象。以下代码说明了浅拷…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

实现拷贝有几点:

1)实现Cloneable接口

2)重写Object类中的clone方法,并将可见性从protect改为public

3)克隆需要调用super.clone(),也就是Object的实现方法

浅拷贝和深拷贝的区别:

浅拷贝是指拷贝对象时仅仅拷贝对象本身(包括对象中的基本变量),而不拷贝对象包含的引用指向的对象。

深拷贝不仅拷贝对象本身,而且拷贝对象包含的引用指向的所有对象。

以下代码说明了浅拷贝的特征:/**

* @author QinGuan

* @date:2016-2-29 下午04:03:03

* @version :3.0

*

*/

package com.cloneTest;

public class personChina implements Cloneable {

public String name;//浅拷贝

public int age;//浅拷贝

public String[] array;//浅拷贝

public vocation vocation;//需要深拷贝的部分

public personChina(String name, int age) {

super();

this.name = name;

this.age = age;

}

@Override

protected Object clone() {

personChina personChina = null;

try {

personChina =  (personChina) super.clone();

//personChina.vocation = (vocation) vocation.clone();①

} catch (CloneNotSupportedException e) {

e.printStackTrace();

}

return personChina;

}

}

/**

* @author QinGuan

* @date:2016-3-1 上午10:39:40

* @version :3.0

*

*/

package com.cloneTest;

public class vocation implements Cloneable{    //person的职业类

public String name;

@Override

protected Object clone() throws CloneNotSupportedException {

return super.clone();

}

}

测试类:/**

* @author QinGuan

* @date:2016-2-29 下午04:09:19

* @version :3.0

*

*/

package com.cloneTest;

public class test {

public static void main(String[] args) throws CloneNotSupportedException {

personChina personChina = new personChina(“张三”, 2);

personChina.array = new String[]{“数组内容”};

personChina.vocation = new vocation();

personChina.vocation.name =”职业”;

personChina personCopy = (personChina) personChina.clone();

personCopy.vocation.name = “职业Copy”; //拷贝后的person修改了职业名字

System.out.println(“拷贝前引用数据类型: ” + personChina.vocation.name);

System.out.println(“拷贝后string: ” + personCopy.name);

System.out.println(“拷贝后数组: ” + personCopy.array[0]);

System.out.println(“拷贝后引用数据类型: ” + personCopy.vocation.name);

}

}

注意①处,注释后,personChina中的vocation属性并没实现克隆,运行结果:

拷贝前引用数据类型: 职业Copy

拷贝后string: 张三

拷贝后数组: 数组内容

拷贝后引用数据类型: 职业Copy

由运行结果可见: 注释掉①处内容,就是浅拷贝,只能拷贝基本数据类型和字符串以及数组,无法拷贝其他引用数据类型,职业内容 前后一致,拷贝后的对象修改了职业,与此同时,拷贝前的职业也随之被改变.

去掉①处的注释,在personChina类克隆的时候也同时将其属性vacation一起进行了克隆,由此实现深拷贝

再次运行程序,结果变为:

拷贝前引用数据类型: 职业

拷贝后string: 张三

拷贝后数组: 数组内容

拷贝后引用数据类型: 职业Copy

拷贝前后,职业相互独立,拷贝后的对象只改变了自己的职业属性.

由此可见,浅拷贝前后的引用类型的属性还是同一个对象,而深拷贝则连同引用类型的属性也一并拷贝了一份,跟拷贝前的同一属性相互独立.

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/189088.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • GC overhead limit exceeded 问题分析与解决

    GC overhead limit exceeded 问题分析与解决今天出现了一个很奇怪的异常:java.lang.OutOfMemoryError:GCoverheadlimitexceeded,超出了GC开销限制。科普了一下,这个是JDK6新添的错误类型。是发生在GC占用大量时间为释放很小空间的时候发生的,是一种保护机制。一般是因为堆太小,导致异常的原因:没有足够的内存。Sun官方对此的定义:超过98%的时间用来做GC并且回收了不到2%…

    2022年5月21日
    61
  • 微信公众平台开发教程Java版(二) 接口配置

    微信公众平台开发教程Java版(二) 接口配置微信公众账号申请完成后,默认开启的是编辑模式。我们需要修改为开发模式。登陆微信公众平台》功能》高级功能先关闭编辑模式,再开启开发模式。申请成为开发者,如果是服务号,需要则会有开发者凭证信息如图如果是订阅号,则只显示服务器配置。下一步就是配置接口服务器了。在公众平台网站的高级功能–开发模式页,点击“成为开发者”按钮,填写U…

    2022年6月29日
    22
  • pycharm 2021年激活码 3月最新注册码

    pycharm 2021年激活码 3月最新注册码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月14日
    519
  • 嵌入式程序员面试题

    接着上一篇博文,说说这次找工作面试遇到的面试题。腾讯,面试职位:后台服务器工程师,大概有七八到笔试题,只能凭印象写出还记得的一些题目1.const的用法2.大小端问题3.二叉排序树的插入4.应用题,一台服务器一分钟的访问量是200W次,要求每隔五到十分钟提示重复登录的用户,请提供设计思路和算法其他一些公司的面试题:1.整型转字符串的实现(不使用库函数)

    2022年4月9日
    39
  • 流水线设计思想_全自动流水线

    流水线设计思想_全自动流水线在硬件电路设计中,流水线设计思想是一种很重要的设计思想,这种思想是一种用面积换速度的思想,用更多的资源来实现高速。(面积就是需要的硬件数量,如触发器的数量)顾名思义,流水线思想,就像工厂中的流水线一样。假设是一个手机组装的流水线,一个三个步骤:A,将电池装入手机起来;B,将屏幕组装起来;C,将外壳组装起来。在上面的三个步骤中,流水线的实现就是:A步骤实现后,将手机发往B,然后A继续组装电池,而不会等待C完成再组装;B和C也是一样。流水线思想就是自己完成自己的功能,不会等待。这在硬件电路中就是一种并行的

    2022年8月14日
    1
  • poj 3259(bellman最短路径)[通俗易懂]

    poj 3259(bellman最短路径)

    2022年1月16日
    36

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号