Java HashMap computeIfPresent() 方法
示例
计算地图中条目的新值
import java.util.HashMap;
public class Main {
public static void main(String[] args) {
HashMap<String, String> capitalCities = new HashMap<String, String>();
capitalCities.put("England", "London");
capitalCities.put("Germany", "Berlin");
capitalCities.put("Norway", "Oslo");
capitalCities.put("USA", "Washington DC");
capitalCities.computeIfPresent("England", (k, v) -> v + "(" + k + ")");
System.out.println(capitalCities);
}
}
定义和用法
该 computeIfPresent()
方法根据其键计算条目的值。 如果具有指定键的条目不存在,或者其值为 null
,则地图不会更改。
值是使用函数计算的,该函数可以通过与 Java 的 apply()
方法兼容的 lambda 表达式定义 BiFunction
接口。
要了解有关 lambda 表达式的更多信息,请参阅我们的 Java Lambda 表达式教程。
语法
public void computeIfPresent(K key, BiFunction function)
K
指的是地图键的数据类型。
参数值
参数 | 描述 |
---|---|
key | 必需。 指定条目的键。 |
function | 必需。 一个 Function 对象或 lambda 表达式,它计算条目的值。函数的第一个参数包含条目的键,第二个参数包含其值。 |
技术细节
返回值 | 由函数计算的值,或者如果地图未更改,则为 null。 |
---|
相关页面
❮ HashMap 方法