时间:2021-05-19
工作中遇到了这个问题,我简单的用代码复现一下,就是一个map,value又为一个set,导致反序列化报错
@Test public void test10() throws Exception { //准备一下数据 Map<String, Set<String>> map = new HashMap<>(); map.put("aaa",new HashSet<String>(){{add("111");add("222");}}); ObjectMapper om = new ObjectMapper(); String str01 = om.writeValueAsString(map); //System.out.println(str01); // {"aaa":["111","222"]} // 正常反序列化,未报错 Map<String, Set<String>> map01 = om.readValue(str01, Map.class); // 取值的时候就会报错了 Set<String> aaa = map01.get("aaa"); }报错:
java.lang.ClassCastException: java.util.ArrayList cannot be cast to java.util.Set
报错信息:无法将list转为set。
再拓展开来,其实当你的Map里面的对象如果是object类型的自定义类型,其实都会报错,无法被强转,那么我们就需要指定jackson反序列化为什么类型,而不是让它自主决定反序列化成什么类型,需要用到TypeReference,直接上代码。
@Testpublic void test10() throws Exception { //准备一下数据 Map<String, Set<String>> map = new HashMap<>(); map.put("aaa",new HashSet<String>(){{add("111");add("222");}}); ObjectMapper om = new ObjectMapper(); String str01 = om.writeValueAsString(map); //System.out.println(str01); // {"aaa":["111","222"]} Map<String, Set<String>> m = om.readValue(str01, new TypeReference<HashMap<String, Set<String>>>() {}); Set<String> aaa = m.get("aaa"); System.out.println(aaa instanceof HashSet); // true}补充知识:Jackson 处理复杂类型(List,map)两种方法
方法一
String jsonString="[{'id':'1'},{'id':'2'}]"; ObjectMapper mapper = new ObjectMapper(); JavaType javaType = mapper.getTypeFactory().constructParametricType(List.class, Bean.class); //如果是Map类型 mapper.getTypeFactory().constructParametricType(HashMap.class,String.class, Bean.class); List<Bean> lst = (List<Bean>)mapper.readValue(jsonString, javaType);当转换完成时一定要用这个转换对象,如果不用这个对象是没有值的.如下,当我打印时这个projects对象才有值,否则projects无值 .
List<AlertProjectInfo> projects = mapper.readValue(subProject, mapper.getTypeFactory().constructCollectionType(List.class, AlertProjectInfo.class));System.out.println(projects.size());方法二
String jsonString="[{'id':'1'},{'id':'2'}]"; ObjectMapper mapper = new ObjectMapper(); List<Bean> beanList = mapper.readValue(jsonString, new TypeReference<List<Bean>>() {});以上这篇解决Jackson反序列化map,set等复杂类型问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Java—IO流对象的序列化和反序列化序列化的基本操作 1.对象序列化,就是将Object转换成byte序列,反之叫对象的反序列化。 2.序列化流(Obje
问题来源:在写二叉树序列化与反序列化时发现序列化函数为char*Serialize1(TreeNode*root)其函数返回类型为char*,但是我在实现的过程
前言本文准确来讲是探讨如何用Jackson来序列化Apacheavro对象,因为简单用Jackson来序列化Apacheavro对象会报错。原因是序列化Sche
1.问题场景我们在使用Redis的时候经常会将对象序列化存储到Redis中,在取出的时候进行反序列化,如果对象过大在进行序列化和反序列化的时候会有一定性能问题。
本文实例讲述了C#实现Xml序列化与反序列化的方法。分享给大家供大家参考。具体实现方法如下:复制代码代码如下://////Xml序列化与反序列化///publi