Java实体类为什么需要序列化和反序列化
最近在学习做微服务的项目,在参考他人的微服务项目时,发现数据库表所对应的实体类都会实现Serializable接口,以往做的项目中并没有遇到过,也没有实现过这个接口,所以好奇实体类为什么需要实现该接口,在查阅相关博客后,进行了总结记录
1. 首先需要知道序列化的概念及使用场景
概念:
序列化其实就是将Java对象转换为字节流的过程,反序列化则相反,是将字节流转换为Java对象
使用场景:
- 需要把内存中的对象状态数据保存到一个文件或者数据库中的时候,这个场景是比较常见的,例如我们利用mybatis框架编写持久层insert对象数据到数据库中时
- 网络通信时需要用套接字在网络中传送对象时,如我们使用RPC协议进行网络通信时
当我们需要把对象的状态信息通过网络进行传输(网络传输),或者需要将对象的状态信息持久化时,就需要把对象进行序列化
序列化对于一门面向对象的编程语言来说还是十分重要的,因为无论什么编程语言,其底层涉及IO操作的部分是由操作系统帮其完成的,而IO操作都是以字节流的方式进行的,所以写操作都需要将编程语言的数据类型转换为字节流,读操作需要将字节流转换为编程语言的特定数据类型
2. 什么是Serializable接口
Serializable接口是用于实现Java类序列化操作而提供的一个语义级接口,一个类只有实现了Serializable接口,它的对象才能被序列化
但该接口中其实没有任何方法和字段,只是起到标记作用,相当于告诉JVM,我需要在进行IO操作时将该对象转换为字节流
3. 为什么要定义serialVersionUID变量
由图中还可以看到定义了一个serialVersionUID变量
对于JVM来说,要进行持久化的类必须要有一个标记,只有持有这个标记JVM才允许类创建的对象可以通过其IO系统转换为字节数据,从而实现持久化,而这个标记就是Serializable接口。
而在反序列化的过程中则需要使用serialVersionUID来确定由哪个类来加载这个对象,所以我们在实现Serializable接口的时候,一般还会要去尽量显示地定义serialVersionUID
如果没有显示地声明该变量,JVM会帮我们自动生成,但有时候可能会出现问题
该变量需要用private修饰,且为常量
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?