集合中的对象在传输中变成了LinkedHashMap解决方案

简介: 集合中的对象在传输中变成了LinkedHashMap解决方案

1、在了解为什么集合中的对象在传输中变成了LinkedHashMap之前,我们先来了解下什么是LinkedHashMap

LinkedHashMap是Java的一种数据结构,它继承自HashMap。HashMap是一种基于哈希表的Map接口的实现类,而LinkedHashMap在HashMap的基础上,增加了一条双向链表来维护元素的插入顺序或访问顺序。

具体来说,当我们向LinkedHashMap中添加元素时,如果该元素已存在,新元素将替换旧元素,并被添加到链表的尾部。当遍历或访问LinkedHashMap中的元素时,它们会按照访问顺序(或插入顺序)进行排列。另外,LinkedHashMap也支持插入null键和null值。

这种特性使LinkedHashMap在一些特定场景下非常有用,例如缓存。对于缓存应用来说,数据的读取速度是非常重要的,而LinkedHashMap由于能够维护元素的访问顺序,因此相比于HashMap,它可以提供更快的读取速度。

2、为什么集合中的对象在传输中变成了LinkedHashMap

在Java中,集合对象在传输过程中变成LinkedHashMap的原因与Java集合的实现机制有关。当我们传递一个集合对象到另一个方法时,如果这个方法对集合进行了修改(如添加、删除或修改元素),那么返回的集合类型可能会变为LinkedHashMap。

这是因为LinkedHashMap是HashMap和LinkedList的结合体,它既实现了基于哈希表的数据存取,又通过维护一条贯穿其全部Entry的双向链表来保证元素的插入顺序或者访问顺序。所以,如果在传输过程中修改了集合的内容,由于这种修改可能会影响到元素的存储位置和顺序,因此有可能会选择使用性能更优的LinkedHashMap作为返回的集合类型。

此外,值得注意的是,这并非一定会发生,具体是否会变成LinkedHashMap还取决于具体的使用场景和代码实现。

3、为什么集合中的对象在传输中变成了LinkedHashMap

集合中的对象在传输过程中变成LinkedHashMap,这种现象可能发生在http传输或者远程调用返回类型为List时。原因可能是由于序列化和反序列化过程导致。解决这类问题,通常需要将LinkedHashMap再转换回原来的对象。

以下是一些可能的解决方案:

  1. 使用fasterxml的Jackson库来进行对象的转换。Jackson库提供了一种方式可以把LinkedHashMap转回原来的对象。
  2. 在进行远程调用的情况下,如果返回类型是DataResults,并且遇到了java.lang.ClassCastException: java.util.LinkedHashMap cannot be cast to Users的问题,可以写一个通用转换类来解决这个问题。
  3. 确保序列化和反序列化的过程是可互操作的。即在发送端和接收端使用的是同一种序列化和反序列化的方式。
  4. 尽量避免在类中使用静态变量和transient关键字,这些因素可能会影响序列化和反序列化的过程。
  5. 通过ObjectMapper将集合转换为新的类型,如下:
List<AddSignVo> resultList = (ArrayList<AddSignVo>)result.get("data");
 // 将LinkedHashMap 转化为 对象的集合
 ObjectMapper objectMapper=new ObjectMapper();
 List<AddSignVo> list = objectMapper.convertValue(resultList, new TypeReference<List<AddSignVo>>(){});


相关文章
|
1天前
|
NoSQL API Redis
数据对象的底层实现方式你都了解吗?
上一小节我们提到的五种数据类型其实就是 Redis 的数据对象,我们先来看看数据对象的类型:Redis 的 key 都是 string 类型的,以上各类型说的其实都是 value 的类型,以下是对象的几个优点:
38 0
数据对象的底层实现方式你都了解吗?
|
1天前
|
安全 索引
【集合】03 Linkedlist原理深入解析
【集合】03 Linkedlist原理深入解析
45 0
|
7月前
集合架构-Map集合及工具类
集合架构-Map集合及工具类
65 0
|
9月前
|
存储 Java 索引
深入了解java集合框架-List集合以及选用
List List实现了Collection,所以他拥有Collection的全部方法
|
10月前
|
存储 算法 安全
HashMap的遍历方式及底层原理
HashMap的遍历方式及底层原理
|
11月前
遍历HashMap的四种方式
遍历HashMap的四种方式
54 0
|
存储 安全 Java
【Java集合类】之 HashSet以及底层逻辑分析
【Java集合类】之 HashSet以及底层逻辑分析
146 0
【Java集合类】之 HashSet以及底层逻辑分析
GoogleGuava - 第 2 章 集合——集合扩展工具类
GoogleGuava - 第 2 章 集合——集合扩展工具类
75 0
GoogleGuava - 第 2 章 集合——集合扩展工具类
LinkedHashMap 底层分析(下)
众所周知 HashMap 是一个无序的 Map,因为每次根据 key 的 hashcode 映射到 Entry 数组上,所以遍历出来的顺序并不是写入的顺序。
LinkedHashMap 底层分析(上)
众所周知 HashMap 是一个无序的 Map,因为每次根据 key 的 hashcode 映射到 Entry 数组上,所以遍历出来的顺序并不是写入的顺序。
http://www.vxiaotou.com