Stream 是 Java8 中处理集合的关键抽象概念,它可以指定你希望对集合进行的操作,可以执行非常复杂的查找、过滤和映射数据等操作。
使用Stream API 对集合数据进行操作,就类似于使用 SQL 执行的数 据库查询。也可以使用 Stream API 来并行执行操作。
简而言之, Stream API 提供了一种高效且易于使用的处理数据的方式。
什么是Stream?
Stream是数据渠道,用于操作数据源(集合、数组等)所生成的元素序列。
集合讲的是数据,流讲的是计算。
- Stream自己不会存储元素;
- Stream不会改变源对象,相反他们会返回一个持有结果的新Stream;
- Stream操作是延迟执行的,这意味着他们会等到需要结果的时候才执行;
Stream操作三个步骤
- 创建Stream:一个数据源,获取一个流;
- 中间操作:一个中间操作链,对数据源的数据进行处理;
- 终止操作:一个终止操作,执行中间操作链,并产生结果;
创建Stream
- Java8中的Collection接口被扩展,提供两个获取流的方式:
- Stream stream():返回一个顺序流;
- Stream parallelStream():返回一个并行流;
- Java8中的Arrays的静态方法stream可以获取数组流;
- Stream stream(T[] array):返回一个流;
List<A> list = Lists.newArrayList();
Map函数的作用就是针对管道流中的每一个数据元素进行转换操作;
// 把一个对象集合中取某个属性的集合 List<Long> productIdList = entityList.stream().mapToLong(Entity::getId).boxed().collect(Collectors.toList());
List<String> alpha = Arrays.asList("Monkey", "Lion", "Giraffe", "Lemur");
// 不使用Stream流
List<String> alphaUpper = new ArrayList<>();
for (String s : alpha) {
alphaUpper.add(s.toUpperCase());
}
// 使用Stream流
List<String> list = alpha.stream().map(s -> s.toUpperCase()).collect(Collectors.toList());
List<String> list2 = alpha.stream().map(String::toUpperCase).collect(Collectors.toList());
// 取对象中的某个属性的集合
List<Long> list2 = list.stream().mapToLong(SalesProduct::getId).boxed().collect(Collectors.toList());
// 同一个对象属性加工
List<SalesProduct> list3 = list.stream().map(e -> {
e.setStoreName(e.getStoreName() + 111);
return e;
}).collect(Collectors.toList());
// 把一个对象转换为另外一个对象
List<User> list4 = list.stream().map(e -> {
User user = new User();
user.setId(e.getId());
user.setName(e.getStoreName());
return user;
}).collect(Collectors.toList());