首页 > java > Java Stream API都可以用来干啥?

Java Stream API都可以用来干啥?

作者:bin

使用stream有什么好处?

  1. 1、代码简洁,函数式编程写出的代码简洁且意图明确,使用stream接口让你从此告别for循环。
  2. 2、多核友好,Java函数式编程使得编写并行程序从未如此简单,你需要的全部就是调用一下parallel()方法。

这里的数据源可以是一个数组,Java容器或I/O channel等。正因如此要得到一个stream通常不会手动创建,而是调用对应的工具方法,比如:

  1. 1、调用Collection.stream()或者Collection.parallelStream()方法
  2. 2、调用Arrays.stream(T[] array)方法

stream和collections有以下不同:

  1. 1、无存储stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组,Java容器或I/O channel等。
  2. 2、为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream
  3. 3、惰式执行stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。
  4. 4、可消费性stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。

stream的操作类型中间操作和结束操作

  1. 1、中间操作总是会惰式执行,调用中间操作只会生成一个标记了该操作的新stream,仅此而已。
  2. 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

您必须 [ 登录 ] 才能发表留言!