一.java8新特性-四大内置核心函数式接口:

java api调用实例 java api函数_迭代器


consumer接口:

java api调用实例 java api函数_JDK1.8_02


supplier接口

java api调用实例 java api函数_JDK1.8_03


supplier接口方法的调用:

java api调用实例 java api函数_API_04


Function函数是式接口:

java api调用实例 java api函数_java api调用实例_05

Predicate断言式接口:

java api调用实例 java api函数_API_06


二.StreamAPI

2.1stream的三个操作步骤:

java api调用实例 java api函数_API_07


2.2创建stream

java api调用实例 java api函数_数据结构_08


2.3 map与flatMap的区别

java api调用实例 java api函数_API_09


2.4 筛选和切片API

java api调用实例 java api函数_API_10


2.5 排序API

java api调用实例 java api函数_java api调用实例_11

2.5 归约-reduce

java api调用实例 java api函数_JDK1.8_12


2.6 Optional类API

java api调用实例 java api函数_API_13

三.接口中可以写default修饰的方法

无存储性:

流不是存储元素的数据结构;相反,它需要从数据结构,数组,生成器函数或IO管道中获取数据并通过流水线地(计算)操作对这些数据进行转换。

函数式编程:

Stream上操作会产生一个新结果,而不会去修改原始数据。比如filter过滤操作它只会根据原始集合中将未被过滤掉的元素生成一个新的Stream,而不是真的去删除集合中的元素。

惰性求值:

很多Stream操作(如filter,map,distinct等)都是惰性实现,这样做为了优化程序的计算。比如说,要从一串数字中找到第一个能被10整除的数,程序并不需要对这一串数字中的每个数字进行测试。流操作分为两种:中间操作(返回值仍为Stream,仍可执行操作),终断操作(结束Stream操作)。中间操作都是惰性操作。

无限数据处理:

集合的大小是有限的,但是流可以对无限的数据执行操作。比如可以使用limit或findFirst这样的操作让Stream操作在有限的时间内结束。

一次性消费:

流只能使用(“消费”)一次,一旦调用终断操作,流就不能再次使用,必须重新创建一个流。就像迭代器一样,遍历一遍后,想要再次遍历需要重新创建一个迭代器。