为什么不应该用Stream.forEach()替换for循环的3个原因

本文探讨了在Java 8中不应轻易用Stream.forEach替换for循环的三个原因:性能损失,对大多数人来说可读性较差,以及在某些情况下可维护性降低。文章通过例子展示了在特定场景下,for循环可能更为合适,强调了在选择编程风格时应考虑到上下文和团队认知的一致性。
摘要由CSDN通过智能技术生成

这篇文章最初发表在jooq.org上 ,这是一个博客,从jOOQ的角度着眼于所有开源,Java和软件开发

太棒了! 我们正在将代码库迁移到Java8。我们将用函数替换所有内容。 扔掉设计模式。 删除对象方向。 对! 我们走吧!

等一下

Java 8已经问世了一年多,而这种兴奋又回到了日常业务中。

baeldung.com从2015年5月开始执行的一项非代表性研究发现, 他们的读者中有38%的人已经采用Java 8 。 在此之前,Typsafe在2014年末进行的一项研究声称,其用户中Java 8的采用率为27%

这对您的代码库意味着什么?

某些Java 7-> Java 8迁移重构是理所当然的。 例如,将Callable传递给ExecutorService

ExecutorService s = ...

// Java 7 - meh...
Future<String> f = s.submit(
    new Callable<String>() {
        @Override
        public String call() {
            return "Hello World";
        }
    }
);

// Java 8 - of course!
Future<String> f = s.submit(() -> "Hello World");

匿名类样式实际上在这里没有添加任何值。

除了这些方面,还有其他较不明显的主题。 例如,是否使用外部迭代器还是内部迭代器 。 另请参阅Neil Gafter于2007年发表的有关永恒主题的有趣读物

以下两个逻辑的结果相同:


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值