Java集合框架: HashSet与HashMap遍历解析

需积分: 48 1 下载量 166 浏览量 更新于2024-09-08 收藏 2KB MD 举报
"这篇文档是关于Java中HashSet和HashMap遍历方法的实例讲解,作者提供了两种数据结构的遍历代码示例。" 在Java编程中,`HashSet`和`HashMap`是两种常用的集合类,分别用于存储不重复的元素集合和键值对。下面将详细解释如何遍历这两个数据结构。 #### 1. HashSet遍历 `HashSet`是一个不允许有重复元素的集合,它基于`HashMap`实现,因此没有顺序性。在Java中,遍历`HashSet`通常有两种方式: 方式一:使用foreach循环 ```Java for (String s : set) { System.out.println(s); } ``` 这段代码使用了Java的增强for循环(也称为foreach循环),它会遍历集合中的每一个元素,无需关心迭代器的细节。 方式二:使用Iterator迭代器 ```Java Iterator<String> it = set.iterator(); while (it.hasNext()) { String s = it.next(); System.out.println(s); } ``` 这种方式通过调用`iterator()`方法获取迭代器,然后使用`hasNext()`检查是否有下一个元素,`next()`获取并返回下一个元素。 #### 2. HashMap遍历 `HashMap`存储键值对,遍历时可以关注键、值或者两者同时。主要有以下三种方式: 方式一:通过keySet遍历 ```Java Set<String> keySet = map.keySet(); Iterator<String> it = keySet.iterator(); while (it.hasNext()) { String key = it.next(); int value = map.get(key); System.out.println("key=" + key); System.out.println("value=" + value); } ``` 这种方式首先获取`HashMap`中的所有键的集合`keySet`,然后通过迭代器遍历键,并使用`get()`方法获取对应的值。 方式二:通过entrySet遍历 ```Java Set<Map.Entry<String, Integer>> entrySet = map.entrySet(); Iterator<Map.Entry<String, Integer>> it = entrySet.iterator(); while (it.hasNext()) { Map.Entry<String, Integer> entry = it.next(); String key = entry.getKey(); int value = entry.getValue(); System.out.println("key=" + key); System.out.println("value=" + value); } ``` 这种方式遍历的是键值对的集合`entrySet`,每个`Map.Entry`对象包含一个键和其对应的值。 方式三:通过values()遍历 ```Java Collection<Integer> values = map.values(); for (Integer value : values) { System.out.println("value=" + value); } ``` 这种方式仅关注`HashMap`中的值,不关心键,适用于只需要处理值的情况。 在实际编程中,根据需求选择合适的遍历方式。例如,如果需要修改元素或键值对,使用迭代器是必要的,因为foreach循环不允许在遍历过程中修改集合。而如果只是简单地打印或统计,foreach循环通常更为简洁。