一、概述
一、
1、Stream关注的是对数据的运算,与CPU打交道
集合关注的是数据的存储,与内存打交道
2、注意事项:
Stream自己不会存储元素
Stream 不会改变源对象.相反,他们会返回一个持有结果的新Steam
Stream操作时延迟执行的,这意味着他们会等到需要结果的时候才执行
3、Stream执行流程
(1)Stream的实例化
a、通过集合
eg:
b、通过数组:
eg:
c、通过Stream的of()
eg:
d、创建无限流
eg:
(2)一系列的中间操作:过滤、映射...
a、筛选与切片
eg:查询工资大与7000的
(2)映射
eg:
c、排序:
eg:
(3)终止操作
a、匹配与查找
b、归约
eg:
c、收集
eg:
tolist
toset
4、说明:
(1)一个中间操作链,对数据源的数据进行处理
(2)一旦执行终止操作,就执行中间操作链,并产生结果.之后,不会再被使用
5、optional类
空指针的报错:数组
eg:
eg2:
结果一定不会为空值,给定空就会返回默认值
总结:optional类为了在程序中避免出现空指针异常而创建的
常用方法:ofNullable(T t)
orElse(T t)