Jackson 和泛型类型参考:处理嵌套泛型对象
Jackson JSON 库允许对复杂对象结构进行强大的处理。然而,在自定义对象中使用泛型类型时会出现一个常见的挑战。
问题陈述:
考虑以下代码:
<code class="java">public class MyWrapper<T> { private MyRequest<T> request; // ... getters and setters } public class MyRequest<T> { private List<T> myobjects; // ... getters and setters }</code>
通用方法尝试将 JSON 对象反序列化为 MyWrapper 实例:
<code class="java">public MyRequest<T> tester() { TypeReference<MyWrapper<T>> typeRef = new TypeReference<MyWrapper<T>>(); MyWrapper<T> requestWrapper = (MyWrapper<T>) JsonConverter.fromJson(jsonRequest, typeRef); return requestWrapper.getRequest(); }</code>
在嵌套 MyRequest 对象上调用 getMyObject() 时会出现此问题。 Jackson 返回一个 LinkedHashMap,而不是所需类型 T 的实例。发生这种情况是因为 Java 类型擦除在编译期间删除了类型信息。
解决方案:
指定要返回确切的类型 T,您需要向 Jackson 提供有关该类型的附加信息。这可以通过使用 Jackson 映射器中的 JavaType 类来实现。
<code class="java">JavaType type = mapper.getTypeFactory(). constructCollectionType(List.class, Foo.class);</code>
将 tester() 方法中的行替换为:
<code class="java">TypeReference<MyWrapper<T>> typeRef = new TypeReference<MyWrapper<T>>(); JavaType requestType = mapper.getTypeFactory(). constructCollectionType(MyRequest.class, type.getType()); MyWrapper<T> requestWrapper = (MyWrapper<T>) JsonConverter.fromJson(jsonRequest, requestType);</code>
这现在指示 Jackson 期望给定类型 Foo 的列表。反序列化 JSON 对象时,它会将其转换为正确的类型。
通过向 Jackson 提供此附加类型信息,您可以准确处理嵌套的泛型对象,确保检索时对象的类型正确。
以上是如何使用 Jackson 反序列化嵌套通用对象:使用 TypeReference 和 JavaType 的指南的详细内容。更多信息请关注PHP中文网其他相关文章!