Map集合的常用方法

简介 

       Java 集合框架中的 Map 是一种非常常用的数据结构,它可以将 key 和 value 进行映射,并提供了丰富的操作方法和函数。在本文中,我们将介绍 Java 集合 Map 的常用方法,以便让读者更好地理解和运用它们。

一、HashMap

1. put

put 方法是 Map 最基本也是最常用的方法之一,它用于向 Map 中添加一个键值对。如果添加的 key 已经存在,则会覆盖原来的 value 值。示例如下:

 Map<String, Integer> map = new HashMap<>();
 map.put("a", 1);
 map.put("b", 2);
 map.put("a", 3);
 System.out.println(map);// 输出 {a=3, b=2}

在这个例子中,我们先将 "a" 对应的 value 设置为 1,再将 "b" 对应的 value 设置为 2。接着,我们又将 "a" 对应的 value 设置为 3,由于 key 值的重复,第二次 put 操作将会覆盖掉原来的值,最终输出结果为 {a=3, b=2}。

2. get

get 方法用于获取指定 key 对应的 value 值,如果 key 不存在,则返回 null。示例如下:

Map<String, Integer> map = new HashMap<>();
map.put("a", 1);
map.put("b", 2);
Integer value = map.get("a");
System.out.println(value); // 输出 1

 在这个例子中,我们通过 get 方法获取了 key 为 "a" 的 value 值,并输出结果为 1。

3. remove

remove 方法用于删除指定 key 对应的键值对。示例如下:

Map<String, Integer> map = new HashMap<>();
map.put("a", 1);
map.put("b", 2);
System.out.println(map); // 输出 {a=1, b=2}
map.remove("a");
System.out.println(map); // 输出 {b=2}

在这个例子中,我们通过 remove 方法删除了 key 为 "a" 的键值对,并将结果输出为 {b=2}。注意,如果 key 不存在,则 remove 方法不会产生任何影响。

4. containsKey 和 containsValue

containsKey 和 containsValue 方法分别用于判断 Map 中是否包含指定的 key 或 value 值。示例如下:

Map<String, Integer> map = new HashMap<>();
map.put("a", 1);
map.put("b", 2);
boolean hasA = map.containsKey("a");
boolean hasC = map.containsKey("c");
boolean hasValue2 = map.containsValue(2);
boolean hasValue3 = map.containsValue(3);
System.out.println(hasA); // 输出 true
System.out.println(hasC); // 输出 false
System.out.println(hasValue2); // 输出 true
System.out.println(hasValue3); // 输出 false

在这个例子中,我们先向 Map 中添加了两个键值对,然后分别使用 containsKey 和 containsValue 方法来判断是否包含指定的 key 或 value 值,并将结果输出。

5. keySet 和 values

keySet 方法返回 Map 中所有 key 的集合,values 方法返回 Map 中所有 value 的集合。示例如下:

Map<String, Integer> map = new HashMap<>();
map.put("a", 1);
map.put("b", 2);
map.put("c", 3);
Set<String> keySet = map.keySet();
Collection<Integer> values = map.values();
System.out.println(keySet); // 输出 [a, b, c]
System.out.println(values); // 输出 [1, 2, 3]

在这个例子中,我们先向 Map 中添加了两个键值对,然后分别使用 keySet 和 values 方法来获取所有的 key 和 value 值,并将结果输出。

6. entrySet

entrySet 方法返回 Map 中所有键值对的集合。每一个元素都是一个 Map.Entry 对象,其中包含一个 key 和一个 value。示例如下:

Map<String, Integer> map = new HashMap<>();
map.put("a", 1);
map.put("b", 2);
Set<Map.Entry<String, Integer>> entries = map.entrySet();
for (Map.Entry<String, Integer> entry : entries) {
System.out.println(entry.getKey() + ": " + entry.getValue());
}

在这个例子中,我们先向 Map 中添加了两个键值对,然后使用 entrySet 方法获取所有的键值对,并通过 for 循环逐一输出每一个元素的 key 和 value 值。

7. size 和 isEmpty

size 方法返回 Map 中键值对的数量,isEmpty 方法判断 Map 是否为空。示例如下:

Map<String, Integer> map = new HashMap<>();
System.out.println(map.size()); // 输出 0
System.out.println(map.isEmpty()); // 输出 true
map.put("a", 1);
System.out.println(map.size()); // 输出 1
System.out.println(map.isEmpty()); // 输出 false

在这个例子中,我们先创建了一个空的 Map 对象,并使用 size 和 isEmpty 方法检查它们的状态。接着,我们向 Map 中添加了一个键值对,并再次使用 size 和 isEmpty 方法检查状态。最终输出结果为 0、true、1 和 false。

8. clear

clear 方法用于清空 Map 中所有的键值对。示例如下:

Map<String, Integer> map = new HashMap<>();
map.put("a", 1);
map.put("b", 2);
System.out.println(map); // 输出 {a=1, b=2}
map.clear();
System.out.println(map); // 输出 {}

在这个例子中,我们先向 Map 中添加了两个键值对,并将其输出。接着,我们使用 clear 方法清空了 Map 中所有的键值对,并将其输出为空集合。

二、LinkedHashMap

常用方法:

put(K key, V value):向哈希表中添加一个键值对,如果键已经存在,则会用新值替换旧值。
get(Object key):获取指定 key 对应的值,如果 key 不存在,则返回 null。
remove(Object key):删除指定 key 对应的键值对,如果 key 不存在,则不会有任何影响。
removeEldestEntry(Map.Entry<K, V> eldest):用于实现 LRU 缓存淘汰算法,可以在子类中重写此方法,控制是否移除最旧的元素。如 果返回 true,则会移除最旧的元素,如果返回 false,则不会有任何影响。
keySet():获取哈希表中所有键的集合。
values():获取哈希表中所有值的集合。
entrySet():获取哈希表中所有键值对的集合。
clear():清空哈希表,删除所有键值对。
size():返回哈希表中键值对的数量。
containsKey(Object key):判断哈希表中是否包含指定的键。
containsValue(Object value):判断哈希表中是否包含指定的值。
clone():创建并返回一个哈希表的副本。
isEmpty():判断哈希表是否为空。
putAll(Map<? extends K, ? extends V> m):将指定映射中的所有映射复制到此映射中。
forEach(BiConsumer<? super K, ? super V> action):对哈希表中的每个键值对执行指定操作。
replaceAll(BiFunction<? super K, ? super V, ? extends V> function):使用指定的函数对哈希表中的每个键值对进行替换。
getOrDefault(Object key, V defaultValue):获取指定键对应的值,如果键不存在,则返回默认值。
merge(K key, V value, BiFunction<? super V, ? super V, ? extends V> remappingFunction):使用指定的函数对哈希表中的指定键的值进行合并。

三、TreeMap

常用方法:

firstKey():获取按照排序规则的第一个键值对的键。
firstEntry():获取按照排序规则的第一个键值对。
lastKey():获取按照排序规则的最后一个键值对的键。
lastEntry():获取按照排序规则的最后一个键值对。
floorKey(K):获取当前键或者比当前键小的键中最大的键。
floorEntry(K):获取当前键或者比当前键小的键中最大的键对应的键值对

 ceilingEntry(K key):返回指定的Key大于或等于的最小值的元素,如果没有,则返回null。

ceilingKey(K key):返回指定的Key大于或等于的最小值的Key,如果没有,则返回null。

clone():返回集合的副本。

comparator():如果使用默认的比较器,就返回null,如果使用其他比较器,就返回比较器的哈希码值。

总结

        Java 集合框架中的 Map 提供了非常丰富的操作方法,可以帮助我们方便地管理和操作 key 和 value 的映射关系。在实际项目开发中,我们需要根据具体的需求选择不同的 Map 实现类,比如 HashMap、TreeMap、LinkedHashMap 和 ConcurrentHashMap 等,并根据实际情况使用不同的方法来完成所需的功能。

        此外,值得注意的是,如果我们在使用 Map 时没有特别指明具体实现类,则默认情况下会使用 HashMap。但是,在多线程环境下,由于 HashMap 是非线程安全的,可能会出现并发修改和死锁等问题。因此,建议在多线程环境下使用 ConcurrentHashMap 或者 Collections.synchronizedMap 方法创建线程安全的 Map 对象。

        另外,Java 8 中引入了 Stream API,可以方便地对 Map 进行操作和处理。例如,我们可以将 Map 转换为流对象,然后使用 filter、map、reduce 等方法进行数据筛选、转换和聚合等操作。

  • 20
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值