Java 8之Map新增方法<转>
在Java 8中的Map.Entry
接口中增加了comparingByKey
, comparingByValue
方法,它们都返回Comparator<Map.Entry<K,V>>
, Comparator
是一个函数接口,主要是方便Lambda表达式的使用。
在Java 8中的Map
接口增加了一些default方法,提升了对key, value操作的便利性。下面是基本数据的定义,通过这些数据说明新增的一些方法。
1
|
Map<Integer, String> map = new HashMap<>();
|
getOrDefault 方法
如果指定的key存在,则返回该key对应的value,如果不存在,则返回指定的值。例子如下
1
|
// key为4不存在,输出 d
|
forEach 方法
遍历Map
中的所有Entry, 对key, value进行处理, 接收参数 (K, V) -> void
, 例子如下
1
|
// 输出1a, 2b, 3c
|
replaceAll 方法
替换Map
中所有Entry的value值,这个值由旧的key和value计算得出,接收参数 (K, V) -> V
, 类似如下代码
1
|
for (Map.Entry<K, V> entry : map.entrySet())
|
例如如下:
1
|
map.replaceAll((key, value) -> (key + 1) + value);
|
putIfAbsent 方法
如果key关联的value不存在,则关联新的value值,返回key关联的旧的值,类似如下代码
1
|
V v = map.get(key);
|
示例代码如下:
1
|
map.putIfAbsent(3, "d");
|
remove 方法
接收2个参数,key和value,如果key关联的value值与指定的value值相等(equals
),则删除这个元素,类似代码如下:
1
|
if (map.containsKey(key) && Objects.equals(map.get(key), value)) {
|
示例代码如下:
1
|
map.remove(1, "b");
|
replace(K key, V oldValue, V newValue) 方法
如果key关联的值与指定的oldValue的值相等,则替换成新的newValue,类似代码如下:
1
|
if (map.containsKey(key) && Objects.equals(map.get(key), value)) {
|
示例代码如下
1
|
map.replace(3, "a", "z");
|
replace(K key, V value) 方法
如果map中存在key,则替换成value值,否则返回null
, 类似代码如下:
1
|
if (map.containsKey(key)) {
|
示例代码如下:
1
|
// 输出旧的值, a
|
computeIfAbsent 方法
如果指定的key不存在,则通过指定的K -> V
计算出新的值设置为key的值,类似代码如下:
1
|
if (map.get(key) == null) {
|
示例代码如下:
1
|
map.computeIfAbsent(1, key -> key + " computed");
|
computeIfPresent 方法
如果指定的key存在,则根据旧的key和value计算新的值newValue, 如果newValue不为null
,则设置key新的值为newValue, 如果newValue为null
, 则删除该key的值,类似代码如下:
1
|
if (map.get(key) != null) {
|
示例代码如下:
1
|
map.computeIfPresent(1, (key, value) -> (key + 1) + value);
|
compute 方法
compute
方法是computeIfAbsent
与computeIfPresent
的综合体。
merge(K key, V value, BiFunction<? super V, ? super V, ? extends V> remappingFunction) 方法
如果指定的key不存在,则设置指定的value值,否则根据key的旧的值oldvalue,value计算出新的值newValue, 如果newValue为null
, 则删除该key,否则设置key的新值newValue。类似如下代码:
1
|
V oldValue = map.get(key);
|
示例代码如下:
1
|
// 存在key为1, 输出 a merge
|