序列化是否必须要实现serializable?
什么是序列化?
简单来说,我们把对象从内存中变成可存储或传输的过程称之为序列化
为什么要序列化?
根本原因:需要将变量或对象从内存中取出来进行存储或传输
具体应用
- 对象保存到文件或数据库
- 网络编程时对象跨平台跨语言传输,也即从windows上序列化的对象可到linux上反序列化,用c#序列化的对象可以被java反序列化。
- RPC远程接口调用
序列化的常见形式
- 转换成二进制字节流的形式,主要将对象序列化成流的形式,用于数据存储
- JSON序列化器,主要将对象序列化成字符串,用于数据传输
- …
java类需不需要实现Serializable接口?
转换成二进制字节流的形式
这种需要序列化的类必须实现Serializable。
常见的例子:把对象存储在Redis服务器中、RPC形式的远程方法调用(微服务使用Dubbo)
转换成JSON字符串的形式
这种类就不需要实现Serializable了
常见的例子:后端暴露的接口返回的JSON格式对象、HTTP形式的远程方法调用(微服务使用的Feign)