Java Stream API高效处理集合数据与并行计算实战
Java 8引入的Stream API彻底改变了集合数据处理的方式,通过声明式函数式编程和内置并行支持,极大提升了开发效率和计算性能。下面通过多个实战场景展示如何高效利用Stream API。
1. 基础数据过滤与转换
利用filter进行条件过滤,map进行数据转换,collect进行结果收集:
List names = Arrays.asList(Alice, Bob, Charlie, David);List result = names.stream() .filter(name -> name.length() > 3) .map(String::toUpperCase) .collect(Collectors.toList());// 输出: [ALICE, CHARLIE, DAVID]
2. 并行流性能优化
通过parallel()方法实现自动并行处理,充分利用多核CPU优势:
List numbers = IntStream.rangeClosed(1, 1000000).boxed().collect(Collectors.toList());long parallelStart = System.currentTimeMillis();long parallelCount = numbers.parallelStream() .filter(n -> n % 2 == 0) .count();long parallelTime = System.currentTimeMillis() - parallelStart;// 并行处理百万数据耗时显著低于顺序流
3. 复杂数据聚合操作
使用Collectors.groupingBy和Collectors.summingInt实现分组统计:
List orders = getOrders();Map salesByProduct = orders.stream() .collect(Collectors.groupingBy( Order::getProductName, Collectors.summingInt(Order::getQuantity) ));// 按产品名称分组计算销售总量
4. 异常处理与资源管理
通过try-with-resources确保流的正确关闭,使用Optional处理可能为空的结果:
try (Stream lines = Files.lines(Paths.get(data.txt))) { Optional result = lines .filter(line -> line.contains(keyword)) .findFirst() .orElse(Not found);} catch (IOException e) { // 异常处理逻辑}5. 自定义收集器实现
通过Collector接口实现自定义聚合逻辑:
Collector personNameCollector = Collector.of( () -> new StringJoiner( | ), (j, p) -> j.add(p.getName().toUpperCase()), StringJoiner::merge, StringJoiner::toString );String names = persons.stream().collect(personNameCollector);
352

被折叠的 条评论
为什么被折叠?



