如何往map中加入map,并且key相同的整合

导读:本篇文章讲解 如何往map中加入map,并且key相同的整合,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

如何往map中加入map,并且key相同的整合

map中加入map,很简单,直接用现有的API即可

map.putAll(map1);

但是,如果两个map中如果key有相同的话,单纯用上述方法,会造成覆盖问题,那如何将key进行整合呢?
比如有一个用于累加的map,还有几个分类的map1,map2,map3,map4
那么只需要对几个分类的map进行一个循环,在循环中判断总和的map中是否存在此map的key即可,话不多说,上代码

Map<String, Integer> map = new HashMap<>(4);
Map<String, Integer> map1 = this.resultAnalyse(id, METRIC_TYPE_FASTING).some();
 Map<String, Integer> map2 = this.resultAnalyse(id, METRIC_TYPE_BEFOREMEAL).some();
 Map<String, Integer> map3 = this.resultAnalyse(id, METRIC_TYPE_AFTERMEAL).some();
 Map<String, Integer> map4 = this.resultAnalyse(id, METRIC_TYPE_NIGHT).some();
 for (Map.Entry<String, Integer> entry :map1.entrySet()) {
     map.put(entry.getKey(), map.containsKey(entry.getKey())? map.get(entry.getKey())+ entry.getValue(): entry.getValue());
 }
 for (Map.Entry<String, Integer> entry :map2.entrySet()) {
     map.put(entry.getKey(), map.containsKey(entry.getKey())? map.get(entry.getKey())+ entry.getValue(): entry.getValue());
 }
 for (Map.Entry<String, Integer> entry :map3.entrySet()) {
     map.put(entry.getKey(), map.containsKey(entry.getKey())? map.get(entry.getKey())+ entry.getValue(): entry.getValue());
 }
 for (Map.Entry<String, Integer> entry :map4.entrySet()) {
     map.put(entry.getKey(), map.containsKey(entry.getKey())? map.get(entry.getKey())+ entry.getValue(): entry.getValue());
 }

代码摆出来,就很容易看出逻辑了,此处关键的地方是,如何对map进行循环

for (Map.Entry<String, Integer> entry :map1.entrySet()) {
     map.put(entry.getKey(), map.containsKey(entry.getKey())? map.get(entry.getKey())+ entry.getValue(): entry.getValue());
 }

上述代码是比较关键的地方~从此可实现map循环,比较简单方便,你学会了吗?

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/65553.html

(1)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!