从支持数据处理操作的源生成的元素序列。
例如:
import static java.util.stream.Collectors.toList; List1.2 流与集合threeHighCaloricDishNames = menu.stream() .filter(d -> d.getCalories() > 300) .map(Dish::getName) .limit(3) .collect(toList()); System.out.println(threeHighCaloricDishNames);
流与集合的区别:
流只能消费一次1
1.2.2 外部和内部迭代- 集合:外部迭代.
Listnames = new ArrayList<>(); Iterator iterator = menu.iterator(); while(iterator.hasNext()) { Dish d = iterator.next(); names.add(d.getName()); }
- 流:内部迭代
List1.3 流的操作names = menu.stream() .map(Dish::getName) .collect(toList());
可以连接起来的流操作称为中间操作,关闭流的操作称为终端操作。
这是因为中间操作一般都可以合并起来,在终端操作时一次性全部处理。
Listnames = menu.stream() .filter (d->{ System.out.println("filtering" + d.getName()); return d.getCalories() > 300; }) .map(d -> { System.out.println("mapping" + d.getName()); return d.getName(); }) .limit(3) .collect(toList()); System.out.println(names);
此代码执行时将打印:
.1.3.2 终端操作filtering pork
mapping pork
filtering beef
mapping beef
filtering chicken
mapping chicken
[pork, beef, chicken]
终端操作会从流的操作中产生结果,其结果是任何不是流的值,如Integer、List
如下例,forEach返回void,要求打印出menu中的每一道菜。
menu.stream().forEach(System.out::println);1.3.3 使用流
总而言之,流的使用包括:
- 一个数据源,如 List,执行一个查询。
- 一个中间操作,产生流水线。
- 一个终端操作,产生流水线的结果。
1.4 总结- 流是“从支持数据处理操作的源生成的一系列元素”。
- 流利用内部迭代:迭代通过filter、map、sorted等操作被抽象掉了。
- 流操作有两类:中间操作和终端操作。
- filter和map等中间操作会返回一个流,并可以链接在一起。可以用它们来设置一条流水线,但并不会生成任何结果。
- forEach和count等终端操作会返回一个非流的值,并处理流水线以返回结果。
- 流中的元素是按需计算的。



