延迟执行代码的原因有很多,具体的如下。
1,在另外一个线程中运行代码
2,多次运行代码
3,在某个算法的正确时间点上运行代码,比如排序中的比较操作
4,当某些情况发生时才运行代码
5,只有在需要的时候才运行代码。
当我们在使用lambda表达式的时候,就应该好好的考虑下希望达到什么样的效果。这里来举一个日志的例子吧。
我们在使用logger.info输出日志,代码如下:logger.info("x的长度是:" + x.length());代码是没问题,但是这里会有一个性能上的问题来,不管上面的代码是否被真的执行,这个x的字符串都会被计算然后传递给info方法,那么为什么我们不能再确定需要打印的时候,再去计算这个字符串呢?
怎么改进一下好呢?惯用的办法就是将上面的这段代码包装成一个无参数的lambda的表达式,只有在需要的时候才能运行代码,这也是使用lambda表达式的一种情况。
现在我们来编码,这段编码实际的运行效果分如下步骤:
1,接受lambda表达式
2,检查他是否应该被调用
3,在需要的时候调用它。
以下是包装过后的代码:
public class Linkin { static final Logger LOG = LoggerFactory.getLogger(Linkin.class); public static void delayDebug(Supplier<String> message) { if (LOG.isDebugEnabled())s { LOG.debug(message.get()); } } public static void main(String[] args) { delayDebug(() -> "这里只是随便的测试"); } }