Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer区别

 更新时间:2023年04月10日 14:41:19   作者:baisq2017  
本文主要介绍了Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、使用Jackson2JsonRedisSerializer序列化反序列化带泛型的List数据

1、使用Jackson2JsonRedisSerializer序列化value的代码:

RedisTemplate<Object, Object> template = new RedisTemplate<Object,Object>();
template.setKeySerializer(new StringRedisSerializer());
template.setValueSerializer(new Jackson2JsonRedisSerializer(Object.class));
UserToken userToken = new UserToken();
userToken.setMobile("176****6708");
List<UserToken> list = Lists.newArrayList(userToken);
redisTemplate.opsForValue().set("test",list,5,TimeUnit.MINUTES);

2、使用Jackson2JsonRedisSerializer序列化后的数据形式:

3、使用Jackson2JsonRedisSerializer反序列化时报错

List<UserToken> list2 = (List<UserToken>)redisTemplate.opsForValue().get("test");
list2.forEach(userToken1 -> System.out.println(userToken1.getMobile()));

java.lang.ClassCastException: java.util.LinkedHashMap cannot be cast to com.com.baisq.model.UserToken

原因:序列化带泛型的数据时,会以map的结构进行存储,反序列化是不能将map解析成对象。

4、解决方案:序列化存储时,转成JSON字符串

UserToken userToken = new UserToken();
userToken.setMobile("176****6708");
List<UserToken> list = Lists.newArrayList(userToken);
redisTemplate.opsForValue().set("test3", JSON.toJSONString(userToken),5,TimeUnit.MINUTES);
String list2 = (String)redisTemplate.opsForValue().get("test3");
JSON.parseArray(list2,UserToken.class).forEach(userToken1 -> System.out.println(userToken1.getMobile()));

二、使用GenericJackson2JsonRedisSerializer序列化反序列化带泛型的List数据

1、使用GenericJackson2JsonRedisSerializer序列化value的代码:

RedisTemplate<Object, Object> template = new RedisTemplate<Object,Object>();
template.setKeySerializer(new StringRedisSerializer());
template.setValueSerializer(new GenericJackson2JsonRedisSerializer());
UserToken userToken = new UserToken();
userToken.setMobile("176****6708");
List<UserToken> list = Lists.newArrayList(userToken);
redisTemplate.opsForValue().set("test2",list,5,TimeUnit.MINUTES);

2、使用GenericJackson2JsonRedisSerializer序列化后的数据形式:

3、使用GenericJackson2JsonRedisSerializer可以正常反序列化

List<UserToken> list2 = (List<UserToken>)redisTemplate.opsForValue().get("test2");
list2.forEach(userToken1 -> System.out.println(userToken1.getMobile()));

4、原因:

使用GenericJackson2JsonRedisSerializer序列化时,会保存序列化的对象的包名和类名,反序列化时以这个作为标示就可以反序列化成指定的对象。

5、也可以以JSON字符串保存:

UserToken userToken = new UserToken();
userToken.setMobile("176****6708");
List<UserToken> list = Lists.newArrayList(userToken);
    redisTemplate.opsForValue().set("test4",JSON.toJSONString(userToken),5,TimeUnit.MINUTES);
String list2 = (String)redisTemplate.opsForValue().get("test4");
JSON.parseArray(list2,UserToken.class).forEach(userToken1 -> System.out.println(userToken1.getMobile()));

三、使用GenericJackson2JsonRedisSerializer和Jackson2JsonRedisSerializerdo都可以正常序列化反序列化非泛型数组对象。

四、GenericJackson2JsonRedisSerializer和Jackson2JsonRedisSerializerdo效率:

long start  = System.currentTimeMillis();
UserToken userToken = new UserToken();
userToken.setMobile("176****6708");
List<UserToken> list = Lists.newArrayListWithCapacity(100);
for (int i = 0; i < 1000; i++) {
   list.add(userToken);
}
redisTemplate.opsForValue().set("test",JSON.toJSONString(list),5,TimeUnit.MINUTES);
String data = (String)redisTemplate.opsForValue().get("test");
List<UserToken> list2 = JSON.parseArray(data, UserToken.class);
long end = System.currentTimeMillis();
long time = end - start;

测试后:

使用GenericJacksonRedisSerializer序列化反序列化耗时:1467

使用Jackson2JsonRedisSerializer序列化反序列化耗时:914

五、总结

1、使用Jackson2JsonRedisSerializer需要指明序列化的类Class,可以使用Obejct.class

2、使用GenericJacksonRedisSerializer比Jackson2JsonRedisSerializer效率低,占用内存高。

3、GenericJacksonRedisSerializer反序列化带泛型的数组类会报转换异常,解决办法存储以JSON字符串存储。

4、GenericJacksonRedisSerializer和Jackson2JsonRedisSerializer都是以JSON格式去存储数据,都可以作为Redis的序列化方式。

到此这篇关于Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer区别的文章就介绍到这了,更多相关Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Redis过期Key删除策略和内存淘汰策略的实现

    Redis过期Key删除策略和内存淘汰策略的实现

    当内存使用达到上限,就无法存储更多数据了,为了解决这个问题,Redis内部会有两套内存回收的策略,过期Key删除策略和内存淘汰策略,本文就来详细的介绍一下这两种方法,感兴趣的可以了解一下
    2024-02-02
  • Redis高并发缓存问题分析及解决过程

    Redis高并发缓存问题分析及解决过程

    文章总结了Redis缓存的六种常见问题及其解决方案:缓存穿透、缓存击穿、缓存雪崩、热点key重建优化、缓存和数据库双写不一致,以及Redis对过期key的三种清除策略,每种问题都提供了详细的原因分析和具体的解决方案
    2025-01-01
  • Redis高级数据类型Hyperloglog、Bitmap的使用

    Redis高级数据类型Hyperloglog、Bitmap的使用

    很多小伙伴在面试中都会被问道 Redis的常用数据结构有哪些?可能很大一部分回答都是 string、hash、list、set、zset,但其实还有Hyperloglog和Bitmap,本文就来介绍一下
    2021-05-05
  • 详解如何使用Redis实现分布式锁

    详解如何使用Redis实现分布式锁

    Redis 作为一个独立的三方系统,其天生的优势就是可以作为一个分布式系统来使用,因此使用 Redis 实现的锁都是分布式锁,所以本文就给大家讲讲如何使用Redis实现分布式锁,感兴趣的小伙伴跟着小编来看看吧
    2023-08-08
  • redis启动报错Can‘t open the log file: No such file or directory

    redis启动报错Can‘t open the log file: No such file or d

    这篇文章主要介绍了redis启动报错Can‘t open the log file: No such file or directory问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • Redis GEO实现附近搜索功能

    Redis GEO实现附近搜索功能

    这篇文章主要介绍了Redis GEO实现附近搜索功能,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2024-12-12
  • Redis慢查询的具体使用

    Redis慢查询的具体使用

    慢查询顾名思义就是比较慢的查询,但是究竟是哪里慢呢?本文详细的介绍了Redis慢查询的具体使用,具有一定的参考价值,感兴趣的可以了解一下
    2023-06-06
  • Redis 实现队列原理的实例详解

    Redis 实现队列原理的实例详解

    这篇文章主要介绍了Redis 实现队列原理的实例详解的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-09-09
  • 浅析Redis分布式锁

    浅析Redis分布式锁

    本篇文章通过实例给大家讲解了Redis分布式锁工作原理以及用法分享,有需要的朋友参考学习下吧。
    2017-12-12
  • Redis安装教程图解

    Redis安装教程图解

    Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。本文就教大家如何安装Redis,需要的朋友可以参考下
    2015-10-10

最新评论