HashMap get()返回值问题

时间:2023-09-29 14:42:02

问题描述:在进行mysql查询必要字段后,需要根据id进行es其它数据字段的查询拼接。使用HashMap以id为key 以查询过来的数据值为value。

代码如下:

 Map<String,Integer> map = null;
if(result != null && result.containsKey("aggregations")){
map = new HashMap<String,Integer>();
JSONTool tool = new JSONTool();
JSONArray buckets = tool.getJSONArray(result, "aggregations.px0.buckets");
if(buckets != null){
for(int i=0; i<buckets.size(); i++){
String key = buckets.getJSONObject(i).getString("key");
int value = buckets.getJSONObject(i).getJSONObject("num").getIntValue("value");
map.put(key, value);
}
}
} //拼装其它获取的字段
if(map != null && !map.isEmpty()){
it = list.iterator();
while(it.hasNext()){
Model mo = it.next();
mo.setNum(map.get(mo .getId()));
}
}

说明:mo.getId()返回的数据类型为Integer

前端拼接数据时,发现没有num字段。debug发现是map.get(mo.getId());返回的竟然是null

于是,将

mo.setNum(map.get(mo .getId()));

改为

mo.setNum(map.get("" + mo .getId()));

总结,原来hashMap是根据key的hash值去找value的,数据类型不同可能hash的值不同。