Colder丶 2018-03-13 01:53 采纳率: 0%
浏览 4037
已结题

Java 8 lambda stream 性能问题

今日有在学习Java8的一些新特征,了解到lambda和stream之后,去importNew无意间逛到了一篇:Java8 Lambda表达式和流操作如何让你的代码变慢5倍,惊讶之下又去了Stack Overflow中逛了一逛,通常情况下,确是基础的代码效率更高,而stream更适合并行的安全的情况下使用,那么既然效率如此之慢,是否这不是一个好的特性?或者以后开发中就要避免使用这在性能上看似“鸡肋”的一个特性?

  • 写回答

2条回答

  • threenewbee 2018-03-13 16:12
    关注

    同学,性能的考量主要是看你编写的代码是不是在性能热区上。举个栗子,你家住北京,要去广州旅行。
    你耗时最多的是乘坐火车从北京到广州这一段。而不是你从家到火车站。你乘坐公共汽车去火车站相比开劳斯莱斯幻影去是比较慢,可能慢了10倍,但是不影响你旅行的时间。
    但是如果你改乘高铁而不是普通火车,则可以起到立竿见影的作用。
    你为什么用java呢?你为什么不用c++甚至自己写机器码呢?你想你的程序还要编译成字节码,用一个叫jvm的东西翻译才能最终被执行,多慢啊。
    写程序的目的当然不仅仅是为了快。对不对。

    评论

报告相同问题?

悬赏问题

  • ¥15 MCNP里如何定义多个源?
  • ¥20 双层网络上信息-疾病传播
  • ¥50 paddlepaddle pinn
  • ¥20 idea运行测试代码报错问题
  • ¥15 网络监控:网络故障告警通知
  • ¥15 django项目运行报编码错误
  • ¥15 请问这个是什么意思?
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services
  • ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏