杰克逊反序列化双

Jackson deserialize Double

我在放心测试中使用 Jackson 反序列化 JSON 时遇到问题。 在我的 JSON 中,我有一个键 "value",它可以是字符串数组或布尔值之类的对象。

{
 "value": ["value1", "value2"]
}

{
"value": 2272204.2426
}

所以我为此字段编写了自定义反序列化程序:

public Object deserialize(JsonParser jp, DeserializationContext ctxt) throws IOException {
        ObjectCodec oc = jp.getCodec();
        JsonNode node = oc.readTree(jp);
        if (node.isArray()) {
            List<String> list = new ArrayList<>();
            for (JsonNode elementNode : node) {
                list.add(oc.treeToValue(elementNode, String.class));
            }
            return list;
        } else {
            if(node.isDouble()) {
                return oc.treeToValue(node, Double.class);
            }
            else if(node.isBoolean()){
                return oc.treeToValue(node, Boolean.class);
            }
            else {
                return oc.treeToValue(node, String.class);
            }
        }
    }

最后我注意到像 2272204.2426 这样的数值被反序列化为 2272204.2 我尝试使用 Gson 对其进行反序列化,并且效果很好。你知道为什么使用 Jackson 时缺少小数部分吗? 我尝试调试代码,我注意到在这一步 JsonNode node = oc.readTree(jp);值为 2272204.2

为什么不使用 Jackson 的 ObjectMapper?与 ObjectCodec 不同,您可以向其中添加 DeserializationFeature。 Mapper 实际上是对 Codec 的扩展,但在这种情况下具有您需要的更多功能。

ObjectMapper mapper = new ObjectMapper();
mapper.enable(DeserializationFeature.USE_BIG_DECIMAL_FOR_FLOATS);

JsonNode node = //node where the value is defined as Double

Double value = null;
try {
    value = mapper.treeToValue(node, Double.class);
}
catch (IOException e) {
    e.printStackTrace();
}

System.out.println(value);

在您的 node.isDouble() 案例中使用上述逻辑