一、使用clone复制
public class CloneTest { public static void main(String[] args) { Person p1 = new Person("张居正",10,new StringBuffer("男"),new Address("北京",3008)); System.out.println("被clone之前的p1=="+p1); Person p2 = (Person) p1.clone(); System.out.println("克隆产生的p2=="+p2); System.out.println("***********************************"); p2.name = "戚继光"; p2.age = 12; p2.sex.append("猛男"); p2.address.city = "天津"; p2.address.number = 9000; System.out.println("改变p2的属性之后:"); System.out.println("p1=="+p1); System.out.println("p2=="+p2); System.out.println("p1和p2的属性都不相等,证明确实实现了深层复制!"); } } //Address类型属于能够直接调用clone方法实现深层复制的其他类型 class Address implements Cloneable{ public String city; public int number; public Address(String city,int number){ this.city = city; this.number = number; } @Override public Object clone() throws CloneNotSupportedException{ return super.clone(); } @Override public String toString(){ return "city="+city+";number="+number; } } //用于序列化的类 //第一,必须实现java.lang.Cloneable接口 class Person implements Cloneable{ //第二,所有属性必须是基本数据类型、String、StringBuffer类型,或者能够直接调用clone方法实现深度复制的其他类型 //注意:StringBuffer类型不能够直接调用clone方法实现直接复制 public String name; public int age; public StringBuffer sex; public Address address; public Person( String name,int age, StringBuffer sex, Address address){ this.name = name; this.age = age; this.sex = sex; this.address = address; } //第三,必须重写clone方法 @Override public Object clone(){ Person p = null; try { //第四,对于基本数据类型和String类型,在调用super.clone()方法时,就已经复制成功了 p = (Person) super.clone(); } catch (CloneNotSupportedException e) { e.printStackTrace(); return null; } //第五,如果属性是StringBuffer类型,则需要使用下面是形式再次给属性赋值 p.sex = new StringBuffer(this.sex.toString()); //第六,如果实行不是基本数据类型、String、StringBuffer类型,则使用一下进行属性的深层复制 try { p.address = (Address) address.clone(); } catch (CloneNotSupportedException e) { p.address = null; e.printStackTrace(); } return p; } @Override public String toString(){ return "name="+name+";age="+age+";sex="+sex.toString()+";address={"+address+"}"; } }
运行结果:
被clone之前的p1==name=张居正;age=10;sex=男;address={city=北京;number=3008} 克隆产生的p2==name=张居正;age=10;sex=男;address={city=北京;number=3008} *********************************** 改变p2的属性之后: p1==name=张居正;age=10;sex=男;address={city=北京;number=3008} p2==name=戚继光;age=12;sex=男猛男;address={city=天津;number=9000}
p1和p2的属性都不相等,证明确实实现了深层复制!
二、使用序列化复制
import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.Serializable; public class SerializableTest { public static void main(String[] args) throws IOException, ClassNotFoundException { Person p1 = new Person("张居正",10,new StringBuffer("男")); System.out.println("序列化之前的p1=="+p1); byte [] bytes = serializeToByte(p1); Person p2 = (Person)deserializeToObject(bytes); System.out.println("反序列化之后的p2=="+p2); System.out.println("***********************************"); p2.name = "戚继光"; p2.age = 12; p2.sex.append("猛男"); System.out.println("改变p2的属性之后:"); System.out.println("p1=="+p1); System.out.println("p2=="+p2); System.out.println("p1和p2的属性都不相等,证明确实实现了深层复制!"); } //将Java对象序列化为byte数组 public static byte [] serializeToByte(Object obj) throws IOException{ ByteArrayOutputStream byteOut = new ByteArrayOutputStream(); ObjectOutputStream out = new ObjectOutputStream(byteOut); out.writeObject(obj); return byteOut.toByteArray(); } //将byte数组反序列化为Java对象 public static Object deserializeToObject(byte [] bytes) throws IOException, ClassNotFoundException{ ByteArrayInputStream byteIn = new ByteArrayInputStream(bytes); ObjectInputStream in =new ObjectInputStream(byteIn); return in.readObject(); } } //用于序列化的类,必须实现java.lang.Serializable接口 class Person implements Serializable{ public String name; public int age; public StringBuffer sex; public Person(String name,int age,StringBuffer sex){ this.name = name; this.age = age; this.sex = sex; } @Override public String toString(){ return "name="+name+";age="+age+";sex="+sex.toString(); } }
注意:被序列化的对象的类必须已经实现java.lang.Serializable接口。
运行结果:
序列化之前的p1==name=张居正;age=10;sex=男 反序列化之后的p2==name=张居正;age=10;sex=男 *********************************** 改变p2的属性之后: p1==name=张居正;age=10;sex=男 p2==name=戚继光;age=12;sex=男猛男
p1和p2的属性都不相等,证明确实实现了深层复制!
参考文章:http://www.ibm.com/developerworks/cn/java/l-jpointer/index.html
相关推荐
tornado-6.4.1-cp38-abi3-musllinux_1_2_i686.whl
tornado-6.1-cp36-cp36m-manylinux2014_aarch64.whl
基于java的ssm停车位短租系统程序答辩PPT.pptx
tornado-6.4b1-cp38-abi3-musllinux_1_1_x86_64.whl
基于java的招生管理系统答辩PPT.pptx
本压缩包资源说明,你现在往下拉可以看到压缩包内容目录 我是批量上传的基于SpringBoot+Vue的项目,所以描述都一样;有源码有数据库脚本,系统都是测试过可运行的,看文件名即可区分项目~ |Java|SpringBoot|Vue|前后端分离| 开发语言:Java 框架:SpringBoot,Vue JDK版本:JDK1.8 数据库:MySQL 5.7+(推荐5.7,8.0也可以) 数据库工具:Navicat 开发软件: idea/eclipse(推荐idea) Maven包:Maven3.3.9+ 系统环境:Windows/Mac
基于java的农机电招平台答辩PPT.pptx
jdk23 甲骨文官方安装包
基于java的机场网上订票系统答辩PPT.pptx
项目经过测试均可完美运行! 环境说明: 开发语言:java jdk:jdk1.8 数据库:mysql 5.7+ 数据库工具:Navicat11+ 管理工具:maven 开发工具:idea/eclipse
基于java的网上书店销售管理系统答辩PPT.pptx
tornado-6.3.3-cp38-abi3-win32.whl
【作品名称】:基于 Jsp+Sqlserver 实现的超市信息管理系统 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】: 系统功能: (1)系统分两种身份:管理员和员工,选择不同的身份进入不同的功能操作界面! (2)商品信息管理:管理员可以添加和维护商品信息,员工只能对商品信息进行查询 (3)员工信息管理:管理员登陆系统后可以可以添加和维护超市员工(收银员)的信息 (4)商品进货管理:管理员登陆系统后可以添加商品进货信息,可以对商品进货信息进行查询和统计,添加商品进进货退货信息,对商品进货退货信息进行查询和统计 (5)商品销售管理:员工(收银员)登陆系统后可以对商品进行销售,可以按时间查询自己的销售业绩;管理员登陆系统后可以按照时间等条件对销售信息进行查询,可以根据小票号登记顾客退货信息,查询顾客退货信息,可以查看员 【资源声明】:本资源作为“参考资料”而不是“定制需求”,代码只能作为参考,不能完全复制照搬。需要有一定的基础看懂代码,自行调试代码并解决报错,能自行添加功能修改代码。
tornado-6.3.2-cp38-abi3-musllinux_1_1_i686.whl
基于java的热带水果商城答辩PPT.pptx
java awt、Swing实现中国象棋可联机版本采用面向对象思想 采用面向对象的思路,实现中国象棋可联机版本,适合初学者,以及对面向对象有更深层次理解的开发者或者同学。 使用原生的java awt、Swing进行窗口式开发 将素材文件夹放在D:\Game路径下 两个工程直接导入Eclipse,即可运行, ps:一个工程运行两次也可以,需要注意端口号,代码默认如果连接的端口号是3003,则监听3004端口,相反同理。联机前需要确保两台计算机同时处于局域网或外网
web前端设计与开发(详细整理)(包含html讲解,css讲解,移动web讲解),合适学习前端的人员进行基础学习,一秒变高手
分析所需的数据和代码都在这里
Listening Exercise 3 Part 2.mp3
链表 删除链表中的重复元素,链表基础