Java 8里 Stream和parallelStream的区别
Java中Stream和parallelStream,前者是单管,后者是多管,运行时间上做一个小对比,直接上代码:
/** * * @author zhangy6 * <p>对比Stream、parallelStream</p> * @date 2017-07-25 */ public class StreamTest { public static void main(String[] args) { String path = "pku_training.utf8"; try { List<String> list = IOUtil.readFile2List(path, "utf-8"); long start = System.currentTimeMillis(); list.stream(). filter(e -> StringUtils.isNotBlank(e)). map(e -> getIdiom(e)). collect(Collectors.toList()); System.out.println("stream : " + (System.currentTimeMillis() - start) + "ms"); start = System.currentTimeMillis(); list.parallelStream(). filter(e -> StringUtils.isNotBlank(e)). map(e -> getIdiom(e)). collect(Collectors.toList()); System.out.println("parallelStream : " + (System.currentTimeMillis() - start) + "ms"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } catch (FileNotFoundException e) { e.printStackTrace(); } } private static List<String> getIdiom(String string) { String[] array = string.split("\\s+"); List<String> list = Arrays.asList(array); return list.stream().filter(e -> e.length() == 4).collect(Collectors.toList()); } }
代码是读取一个分词训练语料,大小7.37MB,然后找出其中四个字的单词/成语,对比一下Stream和ParallelStream运行时间(笔记本win10),结果如下:
stream : 317ms
parallelStream : 90ms
多管就是比单管强很多,线程都不用了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧