⼀、使⽤Jackson2JsonRedisSerializer序列化反序列化带泛型的List数据
1、使⽤Jackson2JsonRedisSerializer序列化value的代码:
RedisTemplate<Object, Object> template = new RedisTemplate<Object,Object>();
(new StringRedisSerializer());
(new Jackson2JsonRedisSerializer());
UserToken userToken = new UserToken();
("176****6708");
List<UserToken> list = (userToken);
().set("test",list,5,);
2、使⽤Jackson2JsonRedisSerializer序列化后的数据形式:
3、使⽤Jackson2JsonRedisSerializer反序列化时报错
List<UserToken> list2 = (List<UserToken>)().get("test");
(userToken1 -> (()));
: cannot be cast to
原因:序列化带泛型的数据时,会以map的结构进⾏存储,反序列化是不能将map解析成对象。
4、解决⽅案:序列化存储时,转成JSON字符串
UserToken userToken = new UserToken();
("176****6708");
List<UserToken> list = (userToken);
().set("test3", (userToken),5,);
String list2 = (String)().get("test3");
(list2,).forEach(userToken1 -> (()));
⼆、使⽤GenericJackson2JsonRedisSerializer序列化反序列化带泛型的List数据
1、使⽤GenericJackson2JsonRedisSerializer序列化value的代码:
RedisTemplate<Object, Object> template = new RedisTemplate<Object,Object>();
(new StringRedisSerializer());
(new GenericJackson2JsonRedisSerializer());
UserToken userToken = new UserToken();
("176****6708");
List<UserToken> list = (userToken);
().set("test2",list,5,);
2、使⽤GenericJackson2JsonRedisSerializer序列化后的数据形式:
3、使⽤GenericJackson2JsonRedisSerializer可以正常反序列化
List<UserToken> list2 = (List<UserToken>)().get("test2");
(userToken1 -> (()));
4、原因:
使⽤GenericJackson2JsonRedisSerializer序列化时,会保存序列化的对象的包名和类名,反序列化时以这个作为标⽰就可以反序列化成
指定的对象。
5、也可以以JSON字符串保存:
UserToken userToken = new UserToken();
("176****6708");
List<UserToken> list = (userToken);
().set("test4",(userToken),5,);
String list2 = (String)().get("test4");
(list2,).forEach(userToken1 -> (()));
三、使⽤GenericJackson2JsonRedisSerializer和Jackson2JsonRedisSerializerdo都可以正常序列化反序列化⾮泛型数组对象。
四、GenericJackson2JsonRedisSerializer和Jackson2JsonRedisSerializerdo效率:
long start = ();
UserToken userToken = new UserToken();
("176****6708");
List<UserToken> list = (100);
for (int i = 0; i < 1000; i++) {
(userToken);
}
().set("test",(list),5,);
String data = (String)().get("test");
List<UserToken> list2 = (data, );
long end = ();
long time = end - start;
测试后:
使⽤GenericJacksonRedisSerializer序列化反序列化耗时:1467
使⽤Jackson2JsonRedisSerializer序列化反序列化耗时:914
五、总结
1、使⽤Jackson2JsonRedisSerializer需要指明序列化的类Class,可以使⽤
2、使⽤GenericJacksonRedisSerializer⽐Jackson2JsonRedisSerializer效率低,占⽤内存⾼。
3、GenericJacksonRedisSerializer反序列化带泛型的数组类会报转换异常,解决办法存储以JSON字符串存储。
4、GenericJacksonRedisSerializer和Jackson2JsonRedisSerializer都是以JSON格式去存储数据,都可以作为Redis的序列化⽅式
相关文章
- GenericJackson2JsonRedisSerializer问题 & Jackson2JsonRedisSerializer & StringRedisSerializer
- Spring项目集成Redis,序列化方式改为Jackson2JsonRedisSerializer
- Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer
- 【SpringBoot+redis的序列化配置之Jackson2JsonRedisSerializer .setObjectMapperis报错】
- ios 中 documents和library 的区别
- 边际电价计算matlab,PJM节点边际电价计算方法和其应用.PDF
- iOS中的#import和class区别
- iOS中成员变量和属性区别
- height和line-height有什么区别?
- Java反射调用get方法和set方法