假设您有以下代码:
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
public class Test {
public static void main(String[] s) {
Map<String, Boolean> whoLetDogsOut = new ConcurrentHashMap<>();
whoLetDogsOut.computeIfAbsent("snoop", k -> f(k));
whoLetDogsOut.computeIfAbsent("snoop", k -> f(k));
}
static boolean f(String s) {
System.out.println("creating a value for \""+s+'"');
return s.isEmpty();
}
}
然后,您将在第二次调用时看到该消息一次,因为该密钥已经有一个值。lambda 表达式中的 只是映射将传递给 lambda 以计算值的键的放置(参数)。因此,在示例中,密钥被传递给函数调用。creating a value for "snoop"
computeIfAbsent
k
k -> f(k)
或者,您可以编写:在没有帮助器方法的情况下获得相同的结果(但您不会看到调试输出)。甚至更简单,因为它是对现有方法的简单委派,您可以编写:此委派不需要编写任何参数。whoLetDogsOut.computeIfAbsent("snoop", k -> k.isEmpty());
whoLetDogsOut.computeIfAbsent("snoop", String::isEmpty);
为了更接近问题中的示例,您可以将其编写为(无论是否命名参数或 )。或者把它写成好像是或 if 是一个实例方法。whoLetDogsOut.computeIfAbsent("snoop", key -> tryToLetOut(key));
k
key
whoLetDogsOut.computeIfAbsent("snoop", MyClass::tryToLetOut);
tryToLetOut
static
whoLetDogsOut.computeIfAbsent("snoop", this::tryToLetOut);
tryToLetOut