一、概述


一、
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)
版权声明:本文为xuruhua原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。