Jackson反序列化map,set等复杂类型

工作中遇到了这个问题,我简单的用代码复现一下,就是一个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,直接上代码。

@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>> m = om.readValue(str01, new TypeReference<HashMap<String, Set<String>>>() {});
    Set<String> aaa = m.get("aaa");
    System.out.println(aaa instanceof HashSet); // true
}

你可能感兴趣的:(json)