《Java8实战》读书笔记(一)

流是什么?

流是Java API的新成员,它允许你以声明的方式处理数据集合(通过类似数据库查询语句来表达,而不是临时编写一个实现)。

使用流的好处

  1. 代码是以声明的方式写的:说明想要完成什么,而不是说明如何实现一个操作
  2. 可以把几个基础的操作链接起来,来表达复杂的数据处理流水线,同时保持代码清晰可读。

filter、sorted、map和collect等操作是与具体线程无关的高层次构件,所以它们内部实现可以是单线程的,也可能透明的充分利用多核架构。

流简介

从支持数据处理操作的源生成的元素序列。

  • 元素序列:跟集合一样,流也提供了一个接口,可以访问特定元素类型的一组有序值。集合是数据结构,主要目的是以特定的时间/空间复杂度存储和访问元素(如ArrayList和LinkedList)。流的目的是计算。集合讲的是数据,流讲的是计算
  • 源:流会使用一个提供数据的源,如集合、数组或输入/输出资源。从有序集合生成流时会保留原来的顺序。由列表生成的流,其元素顺序与列表一致。
  • 数据处理操作:流的数据处理功能支持类似数据库的操作,以及函数式编程语言中的常规操作。流可以顺序执行,也可以并行执行。

流操作的两个重要特点:

  1. 流水线:很多流操作会返回一个流,这样多个操作就可以链接起来,形成一个大的流水线。流水线操作可以看作对数据源进行数据库式查询。
  2. 内部迭代:与使用迭代器显式迭代的集合不同,流的迭代操作是在背后执行的。

流和集合的区别

  1. 集合跟流之间的差异就在于什么时候进行计算
  2. 集合是一个内存中的数据结构,它包含数据结构中目前所有的值。集合中每个元素都得先算出来才能添加到集合中。
  3. 流则是在概念上固定的数据结构(不能添加或删除元素),其元素是按需计算的。

用户仅仅从流中提取需要的值,这些值只会按需生成。这是一种生产者-消费者的关系。从另一个角度来说,流就像是一个延迟创建的集合,只有在消费者要求的时候才会计算值。

流只能遍历一次

外部迭代、内部迭代

外部迭代就是我们在Java8之前用的for-each或Iterator

// for-each
List<String> names = new ArrayList<>();
for(Dish dish : menu) {
    names.add(dish.getName());
}

// Iterator
Iterator<Dish> iterator = menu.iterator();
while(iterator.hasNext()) {
	Dish d = iterator.next();
	names.add(d.getName());
}

内部迭代

List<String> names = menu.stream().map(Dish::getName).collect(toList());

内部迭代时,项目可以透明的并行处理,或者用更优化的顺序进行

流操作可以分为中间操作跟终端操作两大类。

中间操作会返回另一个流,这让多个操作可以连接起来形成一个查询。重要的是,除非流水线上触发一个终端操作,否则中间操作不会进行任何处理。

终端操作会返回任意不是流的结果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值