什么是序列化与反序列化-常见Q&A

Java序列化与反序列化是什么?

序列化: 把Java对象转换成字节序列,然后通过InputStream和OutputStream将内存中的类持久化到硬盘或者网络中传输
反序列化:字节序列恢复为Java对象的过程

等价描述:有序字节流,字节序列


为什么需要序列化与反序列化?

对象、文件、数据,有许多不同的格式,很难统一传输和保存。序列化以后就都是 字节流 了,无论原来是什么东西,都能变成一样的东西,就可以进行通用的格式传输或保存,传输结束以后,要再次使用,就进行反序列化还原,这样对象还是对象,文件还是文件。


序列化应用场景

1、将内存中的类持久化到文件或数据库
2、对象序列化可以实现分布式对象

RMI(即远程调用Remote Method Invocation) 要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时一样。
RPC(Remote Procedure Call,远程过程调用)

3、网络传输


序列化特点

1、递归保存
java对象序列化不仅保留一个对象的数据,而且递归保存对象引用的每个对象的数据。
利用对象序列化可以进行对象的"深复制"


哪些类可以序列化?

1、String
2、枚举
3、实现Serializable接口或Externalizable接口
Serializable 和 Externalizable区别?


什么是serialVersionUID

什么是serialVersionUID?


让某个字段不被持久化,也就是不被数据库存储怎么办?

如何禁止某个字段的持久化


Java中常用的序列化框架:

Java中常用的序列化框架: java原生、gson、fastjson、jackson等。


java原生序列化和反序列化执行路径:

writeObject
writeObject0(判断类是否是自定义类)
writeOrdinaryObject(区分Serializable和Externalizable)
writeSerialData(序列化fields)
invokeWriteObject(反射调用类自己的序列化策略)

如果被序列化的类中定义了 writeObjectreadObject 方法,虚拟机会试图调用对象类里的 writeObjectreadObject 方法,进行用户自定义的序列化和反序列化。

如果被序列化的类没有定义这2个方法,则默认调用是 ObjectOutputStream.defaultWriteObjectObjectInputStream.defaultReadObject 方法来执行序列化和反序列化。


ArrayList的序列化是怎么实现的?

ArrayList的序列化是怎么实现的?

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值