lambda表达式的出现使得JDK8内部发生了很多有趣的变化, 其中就包括惰性计算的特性.
这里以JDK标准库中的Logger为例, 1.8以前的log方法有如下签名:
public void log(Level level, String msg) { if (!isLoggable(level)) { return; } LogRecord lr = new LogRecord(level, msg); doLog(lr); }也就是说客户端程序调用log方法的时候, 无论最终是否触发log行为, msg
始终是要被计算的. 若计算msg
是非常耗时的行为, 那么无疑会造成不必要的开销. 下面是一个调用的例子:
在java 1.8版本出现之后, 该方法多了如下重载:
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()
的调用时. 改进后的调用例子:
新闻热点
疑难解答