首页 > 编程语言 >深挖 Java8的Stream.flatMap:你不知道的流式操作技巧

深挖 Java8的Stream.flatMap:你不知道的流式操作技巧

时间:2025-01-15 17:46:04浏览次数:1  
标签:flatMap java Stream stream Arrays List import Java8

flatMap() 是 Java8 Stream API 的核心方法之一,主要用于将嵌套结构展开并生成一个新的流。它的强大之处在于能够处理复杂数据结构并将其转换为简单的线性流。以下是 flatMap() 的常见用法和应用场景:


1. 将嵌套集合展开为单一流

用法

处理嵌套的 ListSet,将其扁平化为单一流。

示例代码

import java.util.*;
import java.util.stream.Collectors;

public class NestedListExample {
    public static void main(String[] args) {
        List<List<String>> nestedList = Arrays.asList(
            Arrays.asList("a", "b"),
            Arrays.asList("c", "d", "e"),
            Arrays.asList("f", "g")
        );

        // 使用 flatMap 将嵌套集合展开为单一流
        List<String> flatList = nestedList.stream()
                .flatMap(List::stream)
                .collect(Collectors.toList());

        System.out.println("Flattened List: " + flatList);
    }
}

输出

Flattened List: [a, b, c, d, e, f, g]

2. 字符串拆分为单词流

用法

将字符串列表中的每个字符串拆分为单词,然后合并为单一流。

示例代码

import java.util.*;
import java.util.stream.Collectors;

public class StringSplitExample {
    public static void main(String[] args) {
        List<String> sentences = Arrays.asList(
            "Java is powerful",
            "Stream API is useful",
            "flatMap is amazing"
        );

        // 使用 flatMap 拆分字符串为单词流
        List<String> words = sentences.stream()
                .flatMap(sentence -> Arrays.stream(sentence.split(" ")))
                .collect(Collectors.toList());

        System.out.println("Words: " + words);
    }
}

输出

Words: [Java, is, powerful, Stream, API, is, useful, flatMap, is, amazing]

3. 处理多对多关系 (One-to-Many)

用法

通过映射关系生成多个结果,并将其合并为单一流。

示例代码

import java.util.*;
import java.util.stream.Collectors;

public class OneToManyExample {
    public static void main(String[] args) {
        Map<String, List<String>> products = new HashMap<>();
        products.put("Fruits", Arrays.asList("Apple", "Banana"));
        products.put("Vegetables", Arrays.asList("Carrot", "Lettuce"));
        products.put("Dairy", Arrays.asList("Milk", "Cheese"));

        // 使用 flatMap 生成所有商品的流
        List<String> allProducts = products.values().stream()
                .flatMap(List::stream)
                .collect(Collectors.toList());

        System.out.println("All Products: " + allProducts);
    }
}

输出

All Products: [Apple, Banana, Carrot, Lettuce, Milk, Cheese]

4. 处理 Optional 流

用法

将包含 Optional 的流展开为非空值的单一流。

示例代码

import java.util.*;
import java.util.Optional;
import java.util.stream.Collectors;

public class OptionalExample {
    public static void main(String[] args) {
        List<Optional<String>> optionalList = Arrays.asList(
            Optional.of("A"),
            Optional.empty(),
            Optional.of("B"),
            Optional.of("C")
        );

        // 使用 flatMap 提取非空值
        List<String> nonEmptyValues = optionalList.stream()
                .flatMap(Optional::stream)
                .collect(Collectors.toList());

        System.out.println("Non-empty values: " + nonEmptyValues);
    }
}

输出

Non-empty values: [A, B, C]

5. 生成笛卡尔积

用法

两个集合之间生成所有可能的组合。

示例代码

import java.util.*;
import java.util.stream.Collectors;

public class CartesianProductExample {
    public static void main(String[] args) {
        List<String> list1 = Arrays.asList("A", "B", "C");
        List<Integer> list2 = Arrays.asList(1, 2, 3);

        // 使用 flatMap 生成笛卡尔积
        List<String> cartesianProduct = list1.stream()
                .flatMap(str -> list2.stream()
                        .map(num -> str + num))
                .collect(Collectors.toList());

        System.out.println("Cartesian Product: " + cartesianProduct);
    }
}

输出

Cartesian Product: [A1, A2, A3, B1, B2, B3, C1, C2, C3]

6. 动态文件读取

用法

从多个文件读取所有行并合并为一个流。

示例代码

import java.io.IOException;
import java.nio.file.*;
import java.util.stream.Stream;

public class FileReadingExample {
    public static void main(String[] args) throws IOException {
        List<Path> files = Arrays.asList(
            Paths.get("file1.txt"),
            Paths.get("file2.txt")
        );

        // 使用 flatMap 合并多个文件的行
        try (Stream<String> lines = files.stream()
                .flatMap(path -> {
                    try {
                        return Files.lines(path);
                    } catch (IOException e) {
                        e.printStackTrace();
                        return Stream.empty();
                    }
                })) {
            lines.forEach(System.out::println);
        }
    }
}

小结

flatMap() 的核心功能是将多个流或嵌套结构展开为一个流,这使得它在处理复杂数据结构、多对多关系以及动态数据合并时非常有用。通过灵活应用 flatMap(),可以极大地简化代码逻辑,提高数据处理效率和代码可读性。

欢迎follow同名gzh: 加瓦点灯, 每天推送干货知识

本文由mdnice多平台发布

标签:flatMap,java,Stream,stream,Arrays,List,import,Java8
From: https://www.cnblogs.com/javadd/p/18673503

相关文章

  • Windows 行为测试 删除 FileStream 正在读写文件可以继续读写
    测试结论:使用FileShare带Delete的共享方式打开的FileStream正在对文件进行读写过程中,可以对正在读写的文件进行删除。文件删除之后,不影响已经打开的FileStream的读写。且此时使用File.Exists方法判断文件是否存在,返回的是不存在如果删除之后,再次在外部新建同名文件,则......
  • Java8日期时间类
    1、概述java8在java.time包下重新实现了日期相关类。主要有LocalDate、LocalTime、LocalDateTime。每个类功能明确清晰、类之间协作简单、API定义清晰、功能强大无需借助外部工具类,并且线程安全。2、LocalDate表示没有时区的日期,常用于不需要时间信息的日期操作,即年、月和......
  • 『玩转Streamlit』--查看K线的小工具
    在金融市场分析中,查看不同交易对的K线数据是一项基础且重要的工作。今天,我们就来学习如何使用Streamlit构建一个简单的K线查看小工具,让你能够方便地查看不同交易对在不同时间范围内的K线数据。1.环境准备首先,确保已经安装了必要的库。除了Streamlit用于构建界面,还......
  • ecmascript 标准+ 严格模式与常规模式 + flat-flatMap 应用
    文章目录ecmascript历程严格模式与常规模式下的区别及注意事项严格模式下的属性删除Array.prototype.flat()和Array.prototype.flatMap()实例应用ecmascript历程变量声明要求常规模式:在常规模式下,使用var关键字声明变量时会出现变量提升现象。这意味着变......
  • 开发指南089-Stream API
        业务处理中会对从数据库返回集合元素进行加工处理,传统方法是使用for循环。平台遵循现代编程理念(回调函数、链式编程)等推荐使用StreamAPI。    第一步:创建Stream       List对象(通常是jpa调用后的实例类的集合),直接调用stream()函数   ......
  • streamlit实现聊天机器人应用,掌握使用Python构建好看web的页面
     第一个可视化的大模型应用。实现一个带有可视化界面的聊天机器人应用,可以将我们之前实现的聊天机器人转化为一个更加直观、用户友好的,我们的第一个可视化的大模型应用。通过使用Streamlit,我们借助st.columns、st.container、st.chat_input和st.chatmessage等streamlitAPl......
  • Streamlit,Streamlit会话及使用指南,将Streamlit部署到云端,通过Streamlit实现聊天机
    Streamlit介绍Streamlit是一个开源的Python库,专为快速创建数据可视化Web应用而设计。它的核心优势在于能够将简单的Python脚本迅速转换成交互式的Web应用,从而使数据科学家和工程师能够以最少的前端开发投入分享他们的数据分析成果。我们本门课程使用Streamlit构建我们的实战项目......
  • Nginx:Stream模块
    什么是Stream模块?Stream模块是Nginx的一个核心模块,专为处理非HTTP协议的流量(TCP和UDP流量)而设计。它可以用来负载均衡和代理TCP或UDP连接,适用于多种应用场景,如:数据库集群(MySQL、PostgreSQL等)邮件服务器(SMTP、IMAP、POP3)游戏服务器VoIP服务自定义协......
  • 『玩转Streamlit』--集成定时任务
    学习了Streamlit了之后,可以尝试给自己的命令行小工具加一个简单的界面。本篇总结了我改造自己的数据采集的工具时的一些经验。1.概要与常规的程序相比,数据采集任务的特点很明显,比如它一般都是I/O密集型程序,涉及大量网络请求或文件读写,耗费的时间比较长;而且往往是按照一定的时......
  • Java8 日期/时间 工具类
    importorg.apache.commons.lang3.StringUtils;importjava.text.SimpleDateFormat;importjava.time.*;importjava.time.format.DateTimeFormatter;importjava.time.temporal.ChronoUnit;importjava.time.temporal.TemporalAdjusters;importjava.util.Date;impor......