前言
Stream是一个来自数据源的元素队列并支持聚合操作,其中具有以下特性:
- Stream只负责计算,不存储任何元素,元素是特定类型的对象,形成一个队列
- 数据源可以实集合、数组、I/O channel、generator等
- 聚合操作有类似SQL的:filter、map、match、sorted等操作
- Stream流的执行类似于懒加载,用户使用时才执行相应操作
- 可消费性;Stream只能被消费一次,被消费后需要重新生成
本文总结了部分在日常开发中经常接触到的一些Stream流相关的方法,不足之处或有错误欢迎留评,总结的几个方法如下:
- void forEach() : 迭代流中的数据
- Stream map() : 用于映射每个元素到对应的结果
- Stream filter() : 条件过滤器
- Stream sorted() : 排序
- R collect() : 流数据 -> 集合/数组
- 待补充…
forEach()
forEach()源码:
void forEach(Consumer<!--? super T--> action);
Stream().forEach() : 迭代流中的数据
forEach() 的返回类型为void,不会产生新的流
举个栗子:
public void testForEach() {
/**
* 使用forEach()内部迭代
* ints()表示整数类型
* limit()表示限制流个数(次数)
*/
Random random = new Random();
random.ints().limit(10).forEach(System.out::println);
}
运行结果:
再举个灵活一点的栗子:
public void testForEach() {
/**
* 使用forEach()转换集合类型,如List->Map
*/
AtomicInteger i = new AtomicInteger();//原子类型
Map<Integer,String> map = new HashMap<>();
List<String> list = new ArrayList<>(Arrays.asList("Hello",",","world"));
list.stream().forEach(s->{
map.put(i.getAndIncrement(),s);
});
}
<