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