欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer區(qū)別

 更新時(shí)間:2023年04月10日 14:41:19   作者:baisq2017  
本文主要介紹了Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

一、使用Jackson2JsonRedisSerializer序列化反序列化帶泛型的List數(shù)據(jù)

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序列化后的數(shù)據(jù)形式:

3、使用Jackson2JsonRedisSerializer反序列化時(shí)報(bào)錯(cuò)

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

原因:序列化帶泛型的數(shù)據(jù)時(shí),會(huì)以map的結(jié)構(gòu)進(jìn)行存儲(chǔ),反序列化是不能將map解析成對(duì)象。

4、解決方案:序列化存儲(chǔ)時(shí),轉(zhuǎn)成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數(shù)據(jù)

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序列化后的數(shù)據(jù)形式:

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

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

4、原因:

使用GenericJackson2JsonRedisSerializer序列化時(shí),會(huì)保存序列化的對(duì)象的包名和類名,反序列化時(shí)以這個(gè)作為標(biāo)示就可以反序列化成指定的對(duì)象。

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都可以正常序列化反序列化非泛型數(shù)組對(duì)象。

四、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;

測(cè)試后:

使用GenericJacksonRedisSerializer序列化反序列化耗時(shí):1467

使用Jackson2JsonRedisSerializer序列化反序列化耗時(shí):914

五、總結(jié)

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

2、使用GenericJacksonRedisSerializer比Jackson2JsonRedisSerializer效率低,占用內(nèi)存高。

3、GenericJacksonRedisSerializer反序列化帶泛型的數(shù)組類會(huì)報(bào)轉(zhuǎn)換異常,解決辦法存儲(chǔ)以JSON字符串存儲(chǔ)。

4、GenericJacksonRedisSerializer和Jackson2JsonRedisSerializer都是以JSON格式去存儲(chǔ)數(shù)據(jù),都可以作為Redis的序列化方式。

到此這篇關(guān)于Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer區(qū)別的文章就介紹到這了,更多相關(guān)Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談RedisTemplate和StringRedisTemplate的區(qū)別

    淺談RedisTemplate和StringRedisTemplate的區(qū)別

    本文主要介紹了RedisTemplate和StringRedisTemplate的區(qū)別及個(gè)人見解,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • Redis深入了解內(nèi)存淘汰與事務(wù)操作

    Redis深入了解內(nèi)存淘汰與事務(wù)操作

    將Redis用作緩存時(shí),Redis數(shù)據(jù)存在內(nèi)存中,如果內(nèi)存空間用滿,就會(huì)自動(dòng)驅(qū)逐老的數(shù)據(jù)。Redis事務(wù)是一個(gè)單獨(dú)的隔離操作:事務(wù)中的所有命令都會(huì)序列化、按順序地執(zhí)行。事務(wù)在執(zhí)行的過(guò)程中,不會(huì)被其他客戶端發(fā)送來(lái)的命令請(qǐng)求所打斷
    2022-07-07
  • Redis面試必會(huì)的題目

    Redis面試必會(huì)的題目

    這篇文章主要介紹了Redis面試必會(huì)的題目,幫助大家更好的理解和學(xué)習(xí)redis數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2020-08-08
  • 詳解Redis 分布式鎖遇到的序列化問(wèn)題

    詳解Redis 分布式鎖遇到的序列化問(wèn)題

    這篇文章主要介紹了Redis 分布式鎖遇到的序列化問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • 利用ganglia監(jiān)控redis的最新解決方法

    利用ganglia監(jiān)控redis的最新解決方法

    這篇文章主要給大家介紹了如何利用ganglia監(jiān)控redis的最新解決方法,網(wǎng)上的資料基本上就是13年的一篇文章,但發(fā)現(xiàn)文章的內(nèi)容有些許問(wèn)題,于是整理了下最新的解決方法,下面通過(guò)這篇文章來(lái)一起詳細(xì)的看看吧。
    2016-12-12
  • redis 解決key的亂碼問(wèn)題,并清理詳解

    redis 解決key的亂碼問(wèn)題,并清理詳解

    這篇文章主要介紹了redis 解決key的亂碼問(wèn)題,并清理詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • Redis中主鍵失效的原理及實(shí)現(xiàn)機(jī)制剖析

    Redis中主鍵失效的原理及實(shí)現(xiàn)機(jī)制剖析

    這篇文章主要介紹了Redis中主鍵失效的原理及實(shí)現(xiàn)機(jī)制剖析,本文講解了失效時(shí)間的控制、失效的內(nèi)部實(shí)現(xiàn)、Memcached 刪除失效主鍵的方法與 Redis 有何異同、Redis 的主鍵失效機(jī)制會(huì)不會(huì)影響系統(tǒng)性能等內(nèi)容,需要的朋友可以參考下
    2015-06-06
  • Redis實(shí)現(xiàn)分布式鎖的方法示例

    Redis實(shí)現(xiàn)分布式鎖的方法示例

    本篇文章主要介紹了Redis實(shí)現(xiàn)分布式鎖的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-10-10
  • 詳解redis腳本命令執(zhí)行問(wèn)題(redis.call)

    詳解redis腳本命令執(zhí)行問(wèn)題(redis.call)

    這篇文章主要介紹了redis腳本命令執(zhí)行問(wèn)題(redis.call),分別介紹了redis-cli命令行中執(zhí)行及l(fā)inux命令行中執(zhí)行問(wèn)題,本文給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2022-03-03
  • Redis實(shí)現(xiàn)分布式鎖詳解

    Redis實(shí)現(xiàn)分布式鎖詳解

    這篇文章主要介紹了redis如何實(shí)現(xiàn)分布式鎖,文章中有詳細(xì)的示例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2023-04-04

最新評(píng)論