对于以下JSON
{
"employee": {
"insurances": {
"insurance1": "45.1",
"insurance2": "505.5"
}
},
"id":61
}
我使用下面的代码片段从每个字段中检索值
Map<String, Object> insuranceDetails = (Map) ((Map) sourceAsMap.get("employee"))
.get("insurances");
insuranceDetails.get("insurance1");
insuranceDetails.get("insurance2");
想知道是否有更好/有效的方法来实现这一目标?它必须在循环内运行,所以我担心性能。 “ insurance1”和“ insurance2”是固定字段。
答案 0 :(得分:3)
这是一个更好的解决方案,它可以根据json格式创建其属性的实体类。
class Json {
long id;
Map<String, Map<String, Float>> employee;
}
甚至:
class Json {
long id;
Map<String, Insurrences> employee;
}
class Insurrences {
Map<String, Float> insurrences;
}
class Converter {
public static void main(String[] args) {
String json = "{"employee":{"insurances”:{“insurance1”:”45.1","insurance2”:”505.5”}}, “id":61}";
Gson gson = new Gson();
Json jsonObj = gson.fromJson(json, Json.class);
System.out.println(jsonObj.id);
}
}
输出为:61
gson librar:https://github.com/google/gson