Java 的序列化 与 反序列化

2022-01-17 14:20:19 浏览数 (1)

在操作 Redis 遇到了 RedisTemplate 存储对象放进去 Redis中,取出来的时候,无法恢复成Java对象了。真他妈操蛋。耽误我半天时间,于是,准备狠狠的搞一手 序列化相关的问题。

序列化的定义

把对象转换为字节序列的过程称为: 对象的序列化

把字节序列恢复未对象的过程被称为:对象反序列化

为什么要序列化?

我们进行网络传输的时候,是以 二进制数据为单位的。我们在传输的时候 就需要将对象 进行序列化 为字节,这样 我们就可也 进行传输了。比如我们存储Redis数据,假设我们有个 对象叫user,但是 Redis 可识别不了我们Java 虚拟机内存中的 user对象。Redis 只认识 String。将来存储的形式 ,也一定是String。但是 这就带来一个问题。我们将来从Redis读取的字节时候,我们就需要转成Java 对象,我们才能用Java代码进行处理,所以,我们必须按照一个规矩 将对象 进行 所谓的 “加密” 然后 存储后。我们读取的时候 再 “解密“。 “加密” 就叫 序列化 ,”解密” 就叫 反序列化

实现方式

对象 必须实现 Serializable 接口

例如

代码语言:javascript复制
@Data
public class Employee implements java.io.Serializable
{
   private static final long serialVersionUID = 8794571895702522706L;
   public String name;
   public String address;
   public transient int SSN;
   public int number;

}

特殊说明: 解决问题的光鲜,藏着磕Bug的痛苦。 万物皆入轮回,谁也躲不掉! 以上文章,均是我实际操作,写出来的笔记资料,不会出现全文盗用别人文章!烦请各位,请勿直接盗用!

0 人点赞