Java Stream API都可以用来干啥?
作者:bin使用stream有什么好处?
- 1、代码简洁,函数式编程写出的代码简洁且意图明确,使用stream接口让你从此告别for循环。
- 2、多核友好,Java函数式编程使得编写并行程序从未如此简单,你需要的全部就是调用一下
parallel()
方法。
这里的数据源可以是一个数组,Java容器或I/O channel等。正因如此要得到一个stream通常不会手动创建,而是调用对应的工具方法,比如:
- 1、调用
Collection.stream()
或者Collection.parallelStream()
方法 - 2、调用
Arrays.stream(T[] array)
方法
stream和collections有以下不同:
- 1、无存储。stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组,Java容器或I/O channel等。
- 2、为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream。
- 3、惰式执行。stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。
- 4、可消费性。stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。
stream的操作类型,中间操作和结束操作
- 1、中间操作总是会惰式执行,调用中间操作只会生成一个标记了该操作的新stream,仅此而已。
- 2、结束操作会触发实际计算,计算发生时会把所有中间操作积攒的操作以pipeline的方式执行,这样可以减少迭代次数。计算完成之后stream就会失效。
中间操作: concat() distinct() filter() flatMap() limit() map() peek()
skip() sorted() parallel() sequential() unordered()
结束操作: allMatch() anyMatch() collect() count() findAny() findFirst()
forEach() forEachOrdered() max() min() noneMatch() reduce() toArray()
stream方法使用
可以参考:lambda表达式 中最后的demo