浅克隆 深克隆

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

  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的作用是提供高效的内存级临时存储,让序列化-反序列化过程更适合深克隆的轻量、快速需求。

相关推荐
daidaidaiyu7 分钟前
Jetlinks 物联网平台 开源版学习源码分析
java·mqtt·rxjava·tcp
j***788839 分钟前
clickhouse-介绍、安装、数据类型、sql
java
q***47181 小时前
Spring中的IOC详解
java·后端·spring
vx_vxbs662 小时前
【SSM电影网站】(免费领源码+演示录像)|可做计算机毕设Java、Python、PHP、小程序APP、C#、爬虫大数据、单片机、文案
java·spring boot·python·mysql·小程序·php·idea
SunnyDays10112 小时前
如何使用 Java 删除 Word 文档中的水印
java·删除word文档水印
毕设源码-邱学长3 小时前
【开题答辩全过程】以 基于Java企业人事工资管理系统为例,包含答辩的问题和答案
java·开发语言
转转技术团队3 小时前
回收系统架构演进实战:与Cursor结对扫清系统混沌
java·架构·cursor
AI分享猿3 小时前
Java后端实战:SpringBoot接口遇异常请求,轻量WAF兼顾安全与性能
java·spring boot·安全
稚辉君.MCA_P8_Java3 小时前
Gemini永久会员 Java中的四边形不等式优化
java·后端·算法
DKPT3 小时前
ZGC和G1收集器相比哪个更好?
java·jvm·笔记·学习·spring