前言:
此刻大家对“java数组克隆”大约比较关注,小伙伴们都想要分析一些“java数组克隆”的相关资讯。那么小编同时在网上搜集了一些有关“java数组克隆””的相关资讯,希望兄弟们能喜欢,我们一起来了解一下吧!大家好,我是菜菜,一个为 coding 而生,为 debug 奋斗一辈子的地地道道的码农。
日拱一卒系列,旨在通过对 Java 后端常见的面试题进行剖析,少走弯路,利用有限的精力,更加高效的准备和学习。
面试官问:Java 如何实现对象的克隆?
菜菜的回答:在 Java 中实现对象的克隆,在项目研发中,我曾经用过两种方式。
方式一:实现 Cloneable 接口,并重写 Object 类中的 clone() 方法;方式二:实现 Serializable 接口,通过对象的序列化和反序列化实现克隆。
菜菜同学每次面试之后,习惯性的都会认真进行走一遍思考、验证、总结的流程。
菜菜的思考:为什么要用 clone?Java 中的 clone 是浅拷贝还是深拷贝?
菜菜同学确实喜欢举一反三。
使用 clone 的场景大多是对象的属性非常多,而大多数属性的值不变化,只有极个别的属性值是要重新赋值,这样一来就省去很多 new 对象并重新赋值的代码操作,只需使用 clone() 方法轻松搞定对象拷贝,然后针对极个别要重新赋值的字段进行重新赋值即可,相对会简化不少代码。
在 Java 中 clone() 方法默认执行的是浅拷贝,在项目开发中一定要注意这个细节。如果想要完成深拷贝,则需要把该对象引用的其它对象也要 clone 一份,这就要求这个被引用的对象也要实现 Cloneable 接口并实现 Object 类中的 clone() 方法或者直接采用对象的序列化和反序列化完成深拷贝。
菜菜的代码:
方式一:实现 Cloneable 接口,并重写 Object 类中的 clone() 方法。例如 ArrayList 类对于 clone 方法的覆盖实现。
方式二:实现 Serializable 接口,通过对象的序列化和反序列化实现克隆。
public class ReqHead implements Cloneable, Serializable { // ..... 省略很多代码 @Override protected ReqHead clone() throws CloneNotSupportedException { ReqHead readObject = null; try { ByteArrayOutputStream baos = new ByteArrayOutputStream(); ObjectOutputStream oos = new ObjectOutputStream(baos); oos.writeObject(this); ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray()); ObjectInputStream ois = new ObjectInputStream(bais); readObject = (ReqHead) ois.readObject(); } catch (Exception e) { log.warn(e.getLocalizedMessage(), e); } return readObject; }}
日拱一卒,一起聊技术、谈业务、喷架构,少走弯路,不踩大坑。会持续输出精彩分享,敬请期待!
面经:业务开发中你用到了哪些算法(续)?
数据库核心:索引,你知道多少?
Java 程序该怎么优化?命令篇
Java 程序该怎么优化?技巧篇
Java 程序该怎么优化?工具篇
标签: #java数组克隆