Java基础教程之HashMap迭代删除使用方法
前言
map的迭代删除,和我们常见的list,set不太一样,不能直接获取Iteraotr对象,提供的删除方法也是单个的,根据key进行删除,如果我们有个需求,将map中满足某些条件的元素删除掉,要怎么做呢?
I.Map迭代删除
迭代删除,在不考虑并发安全的前提下,我们看下可以怎么支持
1.非常不优雅版本
我们知道map并不是继承自Collection接口的,HashMap也没有提供迭代支持,既然没法直接迭代,那我就老老实的lowb版好了
Mapmap=newHashMap<>(); map.put("a",1); map.put("b",2); map.put("c",3); map.put("d",4); List removeKey=newArrayList<>(); for(Map.Entry e:map.entrySet()){ if(e.getValue()%2==0){ removeKey.add(e.getKey()); } } removeKey.forEach(map::remove);
上面的实现怎么样?并没有什么毛病
(为啥不直接在遍历中删除?)
2.正确姿势版
虽然Map没有迭代,但是它的entrySet有啊,所以我们可以通过它来实现遍历删除
Mapmap=newHashMap<>(); map.put("a",1); map.put("b",2); map.put("c",3); map.put("d",4); Iterator >iterator=map.entrySet().iterator(); Map.Entry entry; while(iterator.hasNext()){ entry=iterator.next(); if(entry.getValue()%2==0){ iterator.remove(); } } System.out.println(map);
上面这个可能是我们经常使用的操作姿势了,利用迭代器来操作元素
3.简洁版
到jdk8之后,针对容器提供了很多简洁的操作方式,迭代删除这方面可以说更加简单了
Mapmap=newHashMap<>(); map.put("a",1); map.put("b",2); map.put("c",3); map.put("d",4); map.entrySet().removeIf(entry->entry.getValue()%2==0);
4.其他
尽信书则不如,已上内容,纯属一家之言,因个人能力有限,难免有疏漏和错误之处,如发现bug或者有更好的建议,欢迎批评指正,不吝感激
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对毛票票的支持。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。