对于以下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”是固定字段。
这是一个更好的解决方案来创建一个实体类,它的属性是根据你的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