当前位置:网站首页>Map常见的遍历方式-keySet 和 entrySet
Map常见的遍历方式-keySet 和 entrySet
2022-08-04 13:26:00 【自律的西瓜L】
1.使用keySet进行遍历
实现步骤:
(1)使用Map集合中的方法keySet(),把Map集合所有的key取出来,存储到一个Set集合中
(2)遍历set集合,获得Map集合中的每一个key
(3)通过Map集合中的方法get(key),通过key找到value
@Test
public void testKeySet() {
Map<String, Integer> map = new ConcurrentHashMap<>(16);
map.put("one",1);
map.put("two",2);
map.put("three",3);
// 1.增强for循环遍历map中的key
for (String key : map.keySet()) {
// 通过key找到对应的value
Integer value = map.get(key);
System.out.println(key + "->" +value);
}
System.out.println("------------------------");
// 2.使用迭代器来进行遍历(map集合中所有的key取出来,存储到Set集合中)
Iterator<String> iteratorKey = map.keySet().iterator();
while (iteratorKey.hasNext()){
String key = iteratorKey.next();
Integer value = map.get(key);
System.out.println(key + "->" +value);
}
}
2.使用entrySet进行遍历
实现步骤:
(1)Map.entrySet()把map的键值映射成Set集合
(2)Map.entrySet迭代器会生成EntryIterator,其返回的实例是一个包含key/value键值对的对象
(3)getKey(): 返回键值对的key
(4)getValue(): 返回键值对的value
@Test
public void testEntrySet() {
Map<String, Integer> map = new ConcurrentHashMap<>(16);
map.put("one",1);
map.put("two",2);
map.put("three",3);
// Map.entrySet迭代器会生成EntryIterator,其返回的实例是一个包含key/value键值对的对象。
// 而keySet中迭代器返回的只是key对象,还需要到map中二次取值。故entrySet要比keySet快一倍左右。
Set<Map.Entry<String, Integer>> entries = map.entrySet();
Iterator<Map.Entry<String, Integer>> entryIterator = entries.iterator();
while (entryIterator.hasNext()){
// 迭代出来的是每一个实例的对象,包含键值对
Map.Entry<String, Integer> entry = entryIterator.next();
String key = entry.getKey();
Integer value = entry.getValue();
System.out.println(key + "->" + value);
}
}
3.对比
(1)keySet获取value只能通过先获取key才能得到value
(2)entrySet在迭代之后可以直接从迭代出来的实例对象中直接获取Key和Value
(3)两个方法遍历的结果都一样,若对查询速度有要求就选entrySet(),entrySet可以提高性能。
边栏推荐
猜你喜欢
随机推荐
漏洞复现 - - - Alibaba Nacos权限认证绕过
RobotFramework二次开发(一)
JSX使用
封装、继承、多态的联合使用实现不同等级学生分数信息的统计
未来已来,只是尚未流行
大势所趋之下的nft拍卖,未来艺术品的新赋能
密码设置十准则
新 Nsight Graph、Nsight Aftermath 版本中的性能提升和增强功能
sqlserver删除重复数据
从零开始配置 vim(7)——自动命令
odoo15 大部分模块都用的附件整理成一独立模块
[UML] Summary of Information System Analysis and Design Knowledge Points
Week 7 Latent Variable Models and Expectation Maximization
倒计时 3 天|一起看云原生 Meetup 的六大议题
MFC的相机双目标定界面设计
【自动微分实现】反向OO实现自动微分(Pytroch核心机制)
使用COLMAP初步三维重建
MogDB/openGauss 3.0 扩容及缩容
Ultra-QuickSort
干掉visio,这个画图神器真的绝了