浅克隆 深克隆

关于对象克隆(复制)的总结如下:

  1. 克隆的分类:
  • 浅克隆:复制对象本身,但对象中的引用类型字段仍指向原对象的引用。

  • 深克隆:完全复制对象及对象中所有引用类型字段指向的 对象, 形成独立的新对象。

  1. 深克隆的主要方式:
  • 重写Object类的clone()方法,通过层层克隆引用类型字段实现深克隆。

  • 序列化和反序列化:将对象写入文件(或其他流)后再读取恢复,可生成多个独立对象,属于深克隆。

  • 使用ByteArrayInputStream和ByteArrayOutputStream:通过字节数组流完成对象的深克隆。 将要克隆的Java对象写到内存中的字节数组中,再从内存中的字节数组中读取对象,读取到的对象就是一个深克隆对象。

具体流程是:

  1. 用 ByteArrayOutputStream 创建内存字节数组输出流,再通过 ObjectOutputStream 将对象序列化到该字节数组中(完成对象的写入);

  1. 用 ByteArrayInputStream 读取上述字节数组,再通过 ObjectInputStream 反序列化出对象(完成对象的读取)。

通过这种"字节数组流+对象流"的组合,借助序列化和反序列化机制,最终得到的对象就是原对象的深克隆版本。

问题:

问题规范:为什么实现对象深克隆时,需要结合ByteArrayOutputStream和ByteArrayInputStream,而不能直接仅用ObjectOutputStream?ByteArrayOutputStream的意义是什么?

回答:

使用ObjectOutputStream进行序列化时,需要指定输出目的地(如文件、网络流等)。而ByteArrayOutputStream的核心意义是提供内存中的字节数组作为序列化的临时存储容器,避免将数据写入磁盘文件等外部存储,直接在内存中完成"写入-读取"的闭环:

  1. 通过ByteArrayOutputStream在内存中创建字节数组,配合ObjectOutputStream将对象序列化到该内存数组中(无需操作外部文件);

  2. 再通过ByteArrayInputStream读取该内存字节数组,配合ObjectInputStream反序列化出克隆对象。

这种方式的优势在于:全程基于内存操作,无需IO磁盘交互,效率更高,且仅用于对象克隆场景时,无需额外处理文件创建、删除等操作,更简洁。

如果仅用ObjectOutputStream而不结合ByteArrayOutputStream,通常需要将对象序列化到文件等外部存储,会增加IO开销,且不符合"内存中快速克隆"的场景需求。因此,ByteArrayOutputStream的作用是提供高效的内存级临时存储,让序列化-反序列化过程更适合深克隆的轻量、快速需求。

相关推荐
seabirdssss4 分钟前
错误: 找不到或无法加载主类 原因: java.lang.ClassNotFoundException
java·开发语言
还是鼠鼠9 分钟前
tlias智能学习辅助系统--SpringAOP-进阶-通知顺序
java·后端·mysql·spring·mybatis·springboot
君莫笑几人回1 小时前
关于记录一下“bug”,在做图片上传的时候出现的小问题
java·开发语言·spring boot
技术不支持1 小时前
Qt Creator 11.0.3 语法高亮bug问题
java·服务器·数据库·qt·bug
pointers_syc2 小时前
【设计模式】2.策略模式
java·设计模式·策略模式
Dcs3 小时前
别再观望了!这才是把 AI 融入日常工作的正确姿势
java
努力写代码的熊大4 小时前
八大排序算法
java·算法·排序算法
做一位快乐的码农4 小时前
基于springboot的在线考试系统/考试信息管理平台
java·struts·spring·eclipse·tomcat·maven·hibernate
创码小奇客5 小时前
Spring Boot 集成 Talos:打造智能调参系统,让模型性能自动飙升
java·spring boot·trae
探索java5 小时前
Spring lookup-method实现原理深度解析
java·后端·spring