Stream.toList()和Collectors.toList()的性能比较
昨天给大家介绍了Java 16中的Stream增强,可以直接通过toList()来转换成List。
主要涉及下面这几种转换方式:
list.stream().toList();
list.stream().collect(Collectors.toList());
list.stream().collect(Collectors.toUnmodifiableList());
然后,看到有网友评论问:Stream.toList()
和Collectors.toList()
的区别是什么?哪个性能好?
处理结果的区别,其实上一篇文章和视频里都有说:
Stream.toList()
返回的List是不可变List,不能增删改Collectors.toList()
返回的是个普通的List,可以增删改Collectors.toUnmodifiableList()
返回的List是不可变List,不能增删改
而至于性能的话,今天我们就来测试一下,看看哪个性能更好。
@BenchmarkMode(Mode.All)
@Fork(1)
@State(Scope.Thread)
@Warmup(iterations = 20, time = 1, batchSize = 10000)
@Measurement(iterations = 20, time = 1, batchSize = 10000)
public class BenchmarkStreamToList {
@Benchmark
public List<Integer> streamToList() {
return IntStream.range(1, 1000).boxed().toList();
}
@Benchmark
public List<Integer> collectorsToList() {
return IntStream.range(1, 1000).boxed().collect(Collectors.toList());
}
@Benchmark
public List<Integer> streamToList() {
return IntStream.range(1, 1000).boxed().toList();
}
}
结果报告:
Benchmark Mode Cnt Score Error Units
BenchmarkStreamToList.collectorsToList thrpt 20 24.422 ± 0.268 ops/s
BenchmarkStreamToList.collectorsToUnmodifiableList thrpt 20 22.784 ± 0.599 ops/s
BenchmarkStreamToList.streamToList thrpt 20 31.779 ± 1.732 ops/s
BenchmarkStreamToList.collectorsToList avgt 20 0.045 ± 0.006 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList avgt 20 0.062 ± 0.035 s/op
BenchmarkStreamToList.streamToList avgt 20 0.040 ± 0.028 s/op
BenchmarkStreamToList.collectorsToList sample 445 0.046 ± 0.002 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.00 sample 0.039 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.50 sample 0.041 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.90 sample 0.057 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.95 sample 0.073 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.99 sample 0.102 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.999 sample 0.150 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.9999 sample 0.150 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p1.00 sample 0.150 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList sample 460 0.044 ± 0.001 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.00 sample 0.042 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.50 sample 0.044 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.90 sample 0.046 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.95 sample 0.047 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.99 sample 0.051 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.999 sample 0.057 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.9999 sample 0.057 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p1.00 sample 0.057 s/op
BenchmarkStreamToList.streamToList sample 655 0.031 ± 0.001 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.00 sample 0.030 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.50 sample 0.031 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.90 sample 0.032 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.95 sample 0.033 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.99 sample 0.035 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.999 sample 0.037 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.9999 sample 0.037 s/op
BenchmarkStreamToList.streamToList:streamToList·p1.00 sample 0.037 s/op
BenchmarkStreamToList.collectorsToList ss 20 0.043 ± 0.001 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList ss 20 0.045 ± 0.004 s/op
BenchmarkStreamToList.streamToList ss 20 0.031 ± 0.001 s/op
从报告中我们可以看到:
- 吞吐量:
streamToList
>collectorsToList
>collectorsToUnmodifiableList
- 平均耗时:
streamToList
>collectorsToList
>collectorsToUnmodifiableList
- p0.9999耗时:
streamToList
>collectorsToUnmodifiableList
>collectorsToList
- 冷启动耗时:
streamToList
>collectorsToList
>collectorsToUnmodifiableList
所以,Stream.toList()
的性能要各方面都要好于Collectors.toList()
和Collectors.toUnmodifiableList()
。
如果您学习过程中如遇困难?可以加入我们超高质量的技术交流群,参与交流与讨论,更好的学习与进步!
本文收录在了我正在连载的《Java新特性专栏》,该系列该用电子书的方式编写,如果想要沉浸式阅读学习的话,可以访问Web版本:https://www.didispace.com/java-features/
再放大一些数据量,试试:
@Benchmark
public List<Integer> streamToList() {
return IntStream.range(1, 10000).boxed().toList();
}
@Benchmark
public List<Integer> collectorsToList() {
return IntStream.range(1, 10000).boxed().collect(Collectors.toList());
}
@Benchmark
public List<Integer> streamToList() {
return IntStream.range(1, 10000).boxed().toList();
}
结果报告:
Benchmark Mode Cnt Score Error Units
BenchmarkStreamToList.collectorsToList thrpt 20 2.186 ± 0.162 ops/s
BenchmarkStreamToList.collectorsToUnmodifiableList thrpt 20 2.184 ± 0.042 ops/s
BenchmarkStreamToList.streamToList thrpt 20 3.538 ± 0.058 ops/s
BenchmarkStreamToList.collectorsToList avgt 20 0.426 ± 0.004 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList avgt 20 0.469 ± 0.016 s/op
BenchmarkStreamToList.streamToList avgt 20 0.293 ± 0.008 s/op
BenchmarkStreamToList.collectorsToList sample 58 0.448 ± 0.049 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.00 sample 0.414 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.50 sample 0.422 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.90 sample 0.458 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.95 sample 0.560 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.99 sample 1.160 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.999 sample 1.160 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p0.9999 sample 1.160 s/op
BenchmarkStreamToList.collectorsToList:collectorsToList·p1.00 sample 1.160 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList sample 60 0.458 ± 0.004 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.00 sample 0.447 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.50 sample 0.455 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.90 sample 0.471 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.95 sample 0.482 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.99 sample 0.492 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.999 sample 0.492 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p0.9999 sample 0.492 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList:collectorsToUnmodifiableList·p1.00 sample 0.492 s/op
BenchmarkStreamToList.streamToList sample 78 0.293 ± 0.012 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.00 sample 0.277 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.50 sample 0.284 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.90 sample 0.309 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.95 sample 0.377 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.99 sample 0.459 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.999 sample 0.459 s/op
BenchmarkStreamToList.streamToList:streamToList·p0.9999 sample 0.459 s/op
BenchmarkStreamToList.streamToList:streamToList·p1.00 sample 0.459 s/op
BenchmarkStreamToList.collectorsToList ss 20 0.474 ± 0.133 s/op
BenchmarkStreamToList.collectorsToUnmodifiableList ss 20 0.493 ± 0.099 s/op
BenchmarkStreamToList.streamToList ss 20 0.325 ± 0.056 s/op
从报告中我们可以看到
- 吞吐量:
streamToList
>collectorsToList
>collectorsToUnmodifiableList
- 平均耗时:
streamToList
>collectorsToList
>collectorsToUnmodifiableList
- p0.9999耗时:
streamToList
>collectorsToUnmodifiableList
>collectorsToList
- 冷启动耗时:
streamToList
>collectorsToList
>collectorsToUnmodifiableList
所以,即使集合内的元素增大,Stream.toList()
的性能在各方面依然都要好于Collectors
下的方法。
好了,今天的分享就到这里,你学会了吗?
本期视频:https://www.bilibili.com/video/BV16Y411F7Pm/
欢迎关注我的公众号:程序猿DD。第一时间了解前沿行业消息、分享深度技术干货、获取优质学习资源
Stream.toList()和Collectors.toList()的性能比较的更多相关文章
- java 数据类型:Stream流 对象转换为集合collect(Collectors.toList()) ;常用方法count,limit,skip,concat,max,min
集合对象.stream() 获取流对象,对元素批处理(不改变原集合) 集合元素循环除了用for循环取出,还有更优雅的方式.forEach 示例List集合获取Stream对象进行元素批处理 impor ...
- GroupBy之后加ToList和不加ToList有什么区别吗?
class Program { static void Main(string[] args) { List<Person> ...
- Stream-快速入门Stream编程
1.什么是流 Stream 不是集合元素,它不是数据结构并不保存数据,它是有关算法和计算的,它更像一个高级版本的 Iterator.原始版本的 Iterator,用户只能显式地一个一个遍历元素并对其执 ...
- List集合去重的一些方法(常规遍历、Set去重、java8 stream去重、重写equals和hashCode方法)
1. 常规元素去重 碰到List去重的问题,除了遍历去重,我们常常想到利用Set集合不允许重复元素的特点,通过List和Set互转,来去掉重复元素. // 遍历后判断赋给另一个list集合,保持原来顺 ...
- JAVA8之 Stream 流(四)
如果说前面几章是函数式编程的方法论,那么 Stream 流就应该是 JAVA8 为我们提供的最佳实践. Stream 流的定义 Stream 是支持串行和并行操作的一系列元素.流操作会被组合到流管道中 ...
- 2020你还不会Java8新特性?方法引用详解及Stream 流介绍和操作方式详解(三)
方法引用详解 方法引用: method reference 方法引用实际上是Lambda表达式的一种语法糖 我们可以将方法引用看作是一个「函数指针」,function pointer 方法引用共分为4 ...
- JDK 8 新特性之函数式编程 → Stream API
开心一刻 今天和朋友们去K歌,看着这群年轻人一个个唱的贼嗨,不禁感慨道:年轻真好啊! 想到自己年轻的时候,那也是拿着麦克风不放的人 现在的我没那激情了,只喜欢坐在角落里,默默的听着他们唱,就连旁边的妹 ...
- JAVA8学习——从使用角度深入Stream流(学习过程)
Stream 流 初识Stream流 简单认识一下Stream:Stream类中的官方介绍: /** * A sequence of elements supporting sequential an ...
- Java 8 Stream API 引入和使用
引入流 流是什么 流是Java API的新成员,它允许你以声明性的方式处理数据集合.可以看成遍历数据集的高级迭代.流可以透明地并行处理,无需编写多线程代码.我们先简单看一下使用流的好处.下面两段代码都 ...
随机推荐
- HTML5标签速查
HTML5标签速查,助你快速了解HTML 5. HTML 5新加入的标签以黑体标识,HTML 5不支持的以斜体标识. 标签 描述 <!--...--> 评论 <!DOCTYPE> ...
- 切图崽的自我修养-[ES6] 迭代器Iterator浅析
Iterator 这真是毅种循环 Iterator不是array,也不是set,不是map, 它不是一个实体,而是一种访问机制,是一个用来访问某个对象的接口规范,为各种不同的数据结构提供统一的访问机制 ...
- 【Weex笔记】-- Animate.css的使用
animate.css是一个使用CSS3的animation制作的动画效果的CSS集合,里面预设了很多种常用的动画,且使用非常简单.本文将详细介绍animate.css的使用. 一,安装辅助依赖 np ...
- IDEA中 Debug 调试工具(图文详解)
DEBUG调试工具 一. Debug 调试工具 1. Debug的作用 2. Debug的使用步骤 3. IDEA中Debug按钮详解 总结 参考博文:https://blog.csdn.net/qq ...
- Spring相关的API-ApplicationContext
1.ClassPathXmlApplicationContext 它是从类的根路径下加载配置文件推荐使用这种 public class UserController { public static v ...
- 帝国cms发布文章对哪些数据表做了操作
帝国cms 发布一篇文章会影响哪些数据表 insert into phome_enewsfile_1(pubid,filename,filesize,adduser,path,filetime,cla ...
- ORM中聚合函数、分组查询、Django开启事务、ORM中常用字段及参数、数据库查询优化
聚合函数 名称 作用 Max() 最大值 Min() 最小值 Sum() 求和 Count() 计数 Avg() 平均值 关键字: aggregate 聚合查询通常都是配合分组一起使用的 关于数据库的 ...
- BurpSuite下提示embedded browser initialisation failed(嵌入式浏览器初始化失败)的解决方法
BurpSuite可谓是渗透测试过程经常使用的神器之一,但使用中经常会碰到奇奇怪怪的问题,比如有时抓http包,发送到Repeater(中继器,也叫重发器)模块后,在右边Render模块下,却无法看到 ...
- windows批处理执行图片爬取脚本
背景 由于测试时需要上传一些图片,而自己保存的图片很少. 为了让测试数据看起来不那么重复,所以网上找了一个爬虫脚本,以下是源码: 1 import requests 2 import os 3 4 c ...
- 最新Mysql大厂面试必会的34问题
目录 1.mysql的隔离级别 2.MYSQL性能优化 常用5种方式 3.索引详解 1.何为索引,有什么用? 2.索引的优缺点 4.什么情况下需要建索引? 5.什么情况下不建索引? 6.索引的底层数据 ...