我为Map提供了一个方便的类包装器,它如下所示:
class MapWrapper {
private Map<String, Integer> wrapped = new HashMap<>();
public void add(String key, Integer count) {/*implementation*/}
// Other modifiers
}我之所以不是直接使用Map,而是使用包装器,是因为我需要使用这些方法间接地访问Map。
当我反/序列化这个对象时,我希望JSON序列化,就像包装类不存在一样。我想:
{
"key1":1,
"key2":2
}对于我的/output中的JSON,而不是(传递给GSON的缺省值是什么):
{
wrapped: {
"key1":1,
"key2":2
}
}如果重要的话,这个对象将包含在另一个对象中,这样GSON上下文反序列化就可以说该对象是一个MapWrapper,而不仅仅是一个映射。
发布于 2015-12-07 16:34:18
为您的类型实现自定义的JsonSerializer / JsonDeserializer:
public class MyTypeAdapter implements JsonSerializer<MapWrapper>, JsonDeserializer<MapWrapper> {
@Override
public JsonElement serialize(MapWrapper src, Type typeOfSrc, JsonSerializationContext context) {
JsonObject obj = new JsonObject();
src.wrapped.entrySet().forEach(e -> obj.add(e.getKey(), new JsonPrimitive(e.getValue())));
return obj;
}
@Override
public MapWrapper deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
MapWrapper wrapper = new MapWrapper();
json.getAsJsonObject().entrySet().forEach(e -> wrapper.wrapped.put(e.getKey(), e.getValue().getAsInt()));
return wrapper;
}
}然后在构造Gson实例时注册它:
Gson gson = new GsonBuilder()
.registerTypeAdapter(MapWrapper.class, new MyTypeAdapter())
.create();你应该可以这样称呼它:
MapWrapper wrapper = new MapWrapper();
wrapper.wrapped.put("key1", 1);
wrapper.wrapped.put("key2", 2);
String json = gson.toJson(wrapper, MapWrapper.class);
System.out.println(json);
MapWrapper newWrapper = gson.fromJson(json, MapWrapper.class);
for(Entry<String, Integer> e : newWrapper.wrapped.entrySet()) {
System.out.println(e.getKey() + ", " + e.getValue());
}这应该打印:
{"key1":1,"key2":2}
key1, 1
key2, 2https://stackoverflow.com/questions/34123721
复制相似问题