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的新成员,它允许你以声明性的方式处理数据集合.可以看成遍历数据集的高级迭代.流可以透明地并行处理,无需编写多线程代码.我们先简单看一下使用流的好处.下面两段代码都 ...
随机推荐
- java中hashCode和equals什么关系,hashCode到底怎么用的
Object类的hashCode的用法:(新手一定要忽略本节,否则会很惨) 马 克-to-win:hashCode方法主要是Sun编写的一些数据结构比如Hashtable的hash算法中用到.因为ha ...
- C++中的算法头文件<algorithm>,<numeric>和<functional>
算法部分主要由头文件<algorithm>,<numeric>和<functional>组成.<algorithm>是所有STL头文件中最大的一个,它是 ...
- Photoshop之用“色彩范围”命令抠像
1. 打开一个文件.执行"选择>色彩范围",勾选"本地化颜色族",然后在任务背景上单击取样. 2. 取好样以后点击确定,图片如下所示,执行"选择 ...
- 在Nginx或Tengine服务器上安装证书
阿里云SSL证书服务支持下载证书并安装到Nginx.Tengine服务器上,本文介绍了证书安装的具体操作. 前提条件 已准备远程登录工具,例如PuTTY或者Xshell. 背景信息 本文档以CentO ...
- Java中读取 .properties 和 .xml 文件
配置文件内容获取 总结内容 1. Java中为什么要使用配置文件 2. Java中常用的配置文件类型有哪些以及它们的特点 Properties配置文件 XML配置文件 总结 总结内容 1. Java中 ...
- EFCore 6.0入门看这篇就够了
前言 作为一直在dotNet行业耕耘的码农,这几年在大大小小项目中也涉及到了许多ORM框架,比如:EFCore,Dapper,NHibernate,SqlSugar等等,这些ORM都有各自的优缺点,大 ...
- WIN进程注入&BypassUAC&令牌窃取
WIN进程注入&BypassUAC&令牌窃取 本地提权-win令牌窃取 假冒令牌可以假冒一个网络中的另一个用户进行各类操作. 所以当一个攻击者需要域管理员的操作权限时候,需通过假冒域管 ...
- 基于STM32单片机的简单红外循迹的实现
初步接触STM32,采用两路红外传感器实现小车循迹,稍显简略,如有不好的地方,欢迎大家指点改正
- vwware workstation虚机网络配置NAT
1.在编辑中选择虚拟网络编辑器,新增NAT模式网络适配器,如下图: 2.在虚拟机中选择设置,在网络适配器中自定义为上一步配置的网络适配器,如下图: 3.进入虚拟机后,编辑/etc/sysconfig/ ...
- Blazor 使用拖放(drag and drop)上传文件
在很多上传文件的应用实例中, 都可以看到[拖放文件到此上传]这种骚功能 ,今天我们就来试试Blazor能不能完成这个想法. 简述HTML5拖放 拖放是HTML5标准的一部分,任何元素都能够拖放,也能够 ...
