一个Java小白的学习之路 个人博客 youngljx.top
为什么要实现序列化?
将对象的状态信息转为存储或传输的形式需要序列化。
1、将对象的状态保存在存储媒体中以便可以在以后重新创建出完全相同的副本;
2、按值将对象从一个应用程序域发送至另一个应用程序域。
实现serializable接口的作用是就是可以把对象存到字节流,然后可以恢复。
所以你想如果你的对象没实现序列化怎么才能进行网络传输呢,要网络传输就得转为字节流
所以在分布式应用中,你就得实现序列化。
另外需要注意的是,在NoSql数据库中,并没有与我们java基本类型对应的数据结构
所以在往nosql数据库中存储时,我们就必须将对象进行序列化
同时在网络传输中我们要注意到两个应用中javabean的serialVersionUID要保持一致,不然就不能正常的进行反序列化
RedisTemplate中的序列化器
被序列化的实体对象必须实现Serializable接口,实体类需要空参构造方法实现反序列化,不然会报错,或者使用lombok注解@NoArgsConstructor
JdkSerializationRedisSerializer :序列化java对象(被序列化的对象必须实现Serializable接口),无法转义成对象
Jackson2JsonRedisSerializer :序列化object对象为json字符串
StringRedisSerializer:简单的字符串序列化,不能序列化Bean
Gene