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