Java中的Map接口有多種遍歷方式,主要有以下幾種方式:
Map<K, V> map = new HashMap<>();
// 添加鍵值對(duì)
Set<Map.Entry<K, V>> entrySet = map.entrySet();
for (Map.Entry<K, V> entry : entrySet) {
K key = entry.getKey();
V value = entry.getValue();
// 處理鍵值對(duì)的邏輯
}
Map<K, V> map = new HashMap<>();
// 添加鍵值對(duì)
Set<K> keySet = map.keySet();
for (K key : keySet) {
V value = map.get(key);
// 處理鍵值對(duì)的邏輯
}
Map<K, V> map = new HashMap<>();
// 添加鍵值對(duì)
Collection<V> values = map.values();
for (V value : values) {
// 處理值的邏輯
}
Map<K, V> map = new HashMap<>();
// 添加鍵值對(duì)
map.forEach((key, value) -> {
// 處理鍵值對(duì)的邏輯
});
需要注意的是,以上遍歷方式中,EntrySet遍歷方式相對(duì)來說更加高效,因?yàn)樗恍枰闅v一次集合,而KeySet和Values遍歷方式需要遍歷兩次集合。另外,Lambda表達(dá)式遍歷方式需要JDK 8及以上的版本才能使用。