问题描述
||
似乎无法将json字符串反序列化为具有type参数的类型。
我想写一个这样的函数:
public <T> Value<T> getValue (json,Class<T> clazz) {
// THE PROBLEM: T becomes Object so the resulting
// Value will hold an Object as value
Type type = new TypeToken<Value<T>>() {}.getType();
return gson.fromJson(json,type);
}
一个例子是:
Value<User> value = new Value<User>(
new User(\"Max\",\"Hu\",new Address(\"5th Av.\",\"NY\")),\"infos\");
// Works fine
String json gson.toJson(value,new TypeToken<Value<User>>() {}.getType())
// dosen\'t work
getValue(json,User.class)
对应的类:
class Value<T> {
T value;
String someInfos;
}
class User {
String name;
String lastName;
Address address;
}
class Address {
String street;
String city;
}
我想念什么吗?
解决方法
我不知道GSON的问题是什么,但很可能是由于TypeToken的静态(编译时)性质所致,它阻止了动态变化(部分是由于Java Type Erasure)。
但是,如果您不必绝对使用GSON,Jackson可以轻松支持此用例。
您将需要构造参数化的JavaType(
TypeFactory.parametricType(Value.class,clazz)
),并将其作为要绑定的类型。就像是:
ObjectMapper mapper = new ObjectMapper();
Value<User> user = mapper.readValue(json,mapper.getTypeFactory().parametericType(Value.class,User.class));
您可以在方法中封装类似的逻辑。我用它来处理请求/响应bean的通用类型(即有效负载是通用的;常见的部分是基本类型)。