一.java8新特性-四大内置核心函数式接口:
consumer接口:
supplier接口
supplier接口方法的调用:
Function函数是式接口:
Predicate断言式接口:
二.StreamAPI
2.1stream的三个操作步骤:
2.2创建stream
2.3 map与flatMap的区别
2.4 筛选和切片API
2.5 排序API
2.5 归约-reduce
2.6 Optional类API
三.接口中可以写default修饰的方法
无存储性:
流不是存储元素的数据结构;相反,它需要从数据结构,数组,生成器函数或IO管道中获取数据并通过流水线地(计算)操作对这些数据进行转换。
函数式编程:
Stream上操作会产生一个新结果,而不会去修改原始数据。比如filter过滤操作它只会根据原始集合中将未被过滤掉的元素生成一个新的Stream,而不是真的去删除集合中的元素。
惰性求值:
很多Stream操作(如filter,map,distinct等)都是惰性实现,这样做为了优化程序的计算。比如说,要从一串数字中找到第一个能被10整除的数,程序并不需要对这一串数字中的每个数字进行测试。流操作分为两种:中间操作(返回值仍为Stream,仍可执行操作),终断操作(结束Stream操作)。中间操作都是惰性操作。
无限数据处理:
集合的大小是有限的,但是流可以对无限的数据执行操作。比如可以使用limit或findFirst这样的操作让Stream操作在有限的时间内结束。
一次性消费:
流只能使用(“消费”)一次,一旦调用终断操作,流就不能再次使用,必须重新创建一个流。就像迭代器一样,遍历一遍后,想要再次遍历需要重新创建一个迭代器。