hashMap简介
hashMap是基于Map的实现,并且允许null value和null key,它不保证存储的数据的顺序。特别要注意的是hashMap不是同步的,要实现同步除了在外部实现同步外,还可以通过Map m = Collections.synchronizedMap(new HashMap())或者使用ConcurrentHashMap类。(面试常问)
compute(key,BiFunction)方法介绍
jdk1.8 API
Attempts to compute a mapping for the specified key and its current mapped value (or null if there is no current mapping)
计算指定键关联的映射值(没有映射值设置null),主要就是将BIFunction的结果值赋予key关联的映射值
public V compute(K key,BiFunction<? super K,? super V, ? extends V> remappingFunction)
Parameters:接受两个参数
- key:关联value的key
- remappingFunction: 函数计算值
Returns:返回更新后的该key映射的value值,若key没有映射的value值,则返回null
注意点
- 如果BiFunction()返回的结果为null,原先存在的key-value将从map中移除,本身就没有,则还是没有。
- 如果重映射函数内抛出异常,这个异常会被继续抛出,映射值不会发送改变
- 如果重映射方法在计算期间修改修改此映射,该实现方法是不能确保检测出错误。
代码
看下代码演示样例基本都能应用了
public static void main(String[] args) {
/** java program to demonstrate*/
//Example 1
HashMap<String, String> classList = new HashMap();
classList.compute("class_1", (k, v) -> (v == null) ? "张三" : v.concat(" 张三"));
System.out.println(classList);
classList.compute("class_1", (k, v) -> v.concat(" 李四"));
System.out.println(classList);
/** output:
* {class_1=张三}
* {class_1=张三 李四}
*/
//Example 2
HashMap<String,Integer> count = new HashMap<>();
for (int i = 0; i < 3; i++) {
count.compute("time", (k, v) -> (v == null) ? 1 : v + 1);
System.out.println(count);
}
/** output:
* {time=1}
* {time=2}
* {time=3}
*/
//Example 3
HashMap<String,Integer> exceptionExample = new HashMap<>();
exceptionExample.put("a",5);
try {
exceptionExample.compute(null, (k, v) -> v + 1);
}catch (NullPointerException e){
System.out.println("Exception: " + e);
}
try {
exceptionExample.compute("b", (k, v) -> v.intValue());
}catch (NullPointerException e){
System.out.println("Exception: " + e);
}
/** output:
* Exception: java.lang.NullPointerException
* Exception: java.lang.NullPointerException
*/
}
复制代码