congyh's blog

Java-通过lambda表达式进行惰性计算

lambda表达式的出现使得JDK8内部发生了很多有趣的变化, 其中就包括惰性计算的特性.

这里以JDK标准库中的Logger为例, 1.8以前的log方法有如下签名:

1
2
3
4
5
6
7
public void log(Level level, String msg) {
if (!isLoggable(level)) {
return;
}
LogRecord lr = new LogRecord(level, msg);
doLog(lr);
}

也就是说客户端程序调用log方法的时候, 无论最终是否触发log行为, msg始终是要被计算的. 若计算msg是非常耗时的行为, 那么无疑会造成不必要的开销. 下面是一个调用的例子:

1
log(Level.WARNING, "Log msg: " + someExpensiveOperation());

在java 1.8版本出现之后, 该方法多了如下重载:

1
2
3
4
5
6
7
public void log(Level level, Supplier<String> msgSupplier) {
if (!isLoggable(level)) {
return;
}
LogRecord lr = new LogRecord(level, msgSupplier.get());
doLog(lr);
}

Supplier是一个FunctionalInterface, 也就是说现在的log方法可以接受一个无参的lambda表达式作为参数, 而计算的过程也被延迟到了supplier.get()的调用时. 改进后的调用例子:

1
2
// 注意: 传入的lambda表达式并不会立即执行, 而是在log中判断isLoggable(level)成功后才会执行
log(Level.WARNING, () -> "Log msg: " + someExpensiveOperation());
坚持原创技术分享,您的支持将鼓励我继续创作!

热评文章