博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JDK工具类之java.util.stream包的源码学习
阅读量:4030 次
发布时间:2019-05-24

本文共 2981 字,大约阅读时间需要 9 分钟。

Stream为何而生

Stream 作为 Java 8 的一大亮点,它与 java.io 包里的 InputStream 和 OutputStream 是完全不同的概念。它也不同于 StAX 对 XML 解析的 Stream,也不是 Amazon Kinesis 对大数据实时处理的 Stream。Java 8 中的 Stream 是对集合(Collection)对象功能的增强,它专注于对集合对象进行各种非常便利、高效的聚合操作(aggregate operation),或者大批量数据操作 (bulk data operation)。Stream API 借助于同样新出现的 Lambda 表达式,极大的提高编程效率和程序可读性。同时它提供串行和并行两种模式进行汇聚操作,并发模式能够充分利用多核处理器的优势,使用 fork/join 并行方式来拆分任务和加速处理过程。通常编写并行代码很难而且容易出错, 但使用 Stream API 无需编写一行多线程的代码,就可以很方便地写出高性能的并发程序。所以说,Java 8 中首次出现的 java.util.stream 是一个函数式语言+多核时代综合影响的产物。

源码分析

依赖关系

luogw@luogw-MacBook-Pro stream$ ag 'import java.util' |  awk 'BEGIN{FS=":"} {print $3}' | awk 'BEGIN{FS=" "} {print $2}' | awk 'BEGIN{FS=";"} {print $1}' | sort -ujava.util.AbstractMapjava.util.AbstractSetjava.util.ArrayDequejava.util.ArrayListjava.util.Arraysjava.util.Collectionjava.util.Collectionsjava.util.Comparatorjava.util.Dequejava.util.DoubleSummaryStatisticsjava.util.EnumMapjava.util.EnumSetjava.util.HashMapjava.util.HashSetjava.util.IntSummaryStatisticsjava.util.Iteratorjava.util.LinkedHashSetjava.util.Listjava.util.LongSummaryStatisticsjava.util.Mapjava.util.Objectsjava.util.Optionaljava.util.OptionalDoublejava.util.OptionalIntjava.util.OptionalLongjava.util.PrimitiveIteratorjava.util.Setjava.util.Spliteratorjava.util.Spliteratorsjava.util.StringJoinerjava.util.concurrent.ConcurrentHashMapjava.util.concurrent.ConcurrentMapjava.util.concurrent.CountedCompleterjava.util.concurrent.ForkJoinPooljava.util.concurrent.ForkJoinTaskjava.util.concurrent.atomic.AtomicBooleanjava.util.concurrent.atomic.AtomicLongjava.util.concurrent.atomic.AtomicReferencejava.util.function.BiConsumerjava.util.function.BiFunctionjava.util.function.BinaryOperatorjava.util.function.BooleanSupplierjava.util.function.Consumerjava.util.function.DoubleBinaryOperatorjava.util.function.DoubleConsumerjava.util.function.DoubleFunctionjava.util.function.DoublePredicatejava.util.function.DoubleSupplierjava.util.function.DoubleToIntFunctionjava.util.function.DoubleToLongFunctionjava.util.function.DoubleUnaryOperatorjava.util.function.Functionjava.util.function.IntBinaryOperatorjava.util.function.IntConsumerjava.util.function.IntFunctionjava.util.function.IntPredicatejava.util.function.IntSupplierjava.util.function.IntToDoubleFunctionjava.util.function.IntToLongFunctionjava.util.function.IntUnaryOperatorjava.util.function.LongBinaryOperatorjava.util.function.LongConsumerjava.util.function.LongFunctionjava.util.function.LongPredicatejava.util.function.LongSupplierjava.util.function.LongToDoubleFunctionjava.util.function.LongToIntFunctionjava.util.function.LongUnaryOperatorjava.util.function.ObjDoubleConsumerjava.util.function.ObjIntConsumerjava.util.function.ObjLongConsumerjava.util.function.Predicatejava.util.function.Supplierjava.util.function.ToDoubleFunctionjava.util.function.ToIntFunctionjava.util.function.ToLongFunctionjava.util.function.UnaryOperator

如上所示,Stream包依赖集合框架,并发编程包(java.util.concurrent),函数式接口(java.util.function),即要先搞清楚依赖方的实现先!

实现原理

参考资料

转载地址:http://nxmbi.baihongyu.com/

你可能感兴趣的文章
WAV文件解析
查看>>
DAC输出音乐2-解决pu pu 声
查看>>
WPF中PATH使用AI导出SVG的方法
查看>>
WPF UI&控件免费开源库
查看>>
QT打开项目提示no valid settings file could be found
查看>>
Win10+VS+ESP32环境搭建
查看>>
Ubuntu+win10远程桌面
查看>>
flutter-实现圆角带边框的view(android无效)
查看>>
flutter-实现一个下拉刷新上拉加载的列表
查看>>
android 代码实现圆角
查看>>
postman调试webservice接口
查看>>
flutter-解析json
查看>>
android中shader的使用
查看>>
java LinkedList与ArrayList迭代器遍历和for遍历对比
查看>>
Android DataBinding使用2-Recycleview
查看>>
drat中构造方法
查看>>
JavaScript的一些基础-数据类型
查看>>
JavaScript基础知识(2)
查看>>
转载一个webview开车指南以及实际项目中的使用
查看>>
关于activity保存页面状态的两个方法
查看>>