java8中stream的map和flatmap的理解

转自https://blog.csdn.net/wynjauu/article/details/78741093

假如我们有这样一个需求给定单词列表["Hello","World"],你想要返回列表["H","e","l", "o","W","r","d"],

对于这样的需求,我们可能想到的第一个版本可能是这样子的:

words.stream()
.map(word -> word.split(""))
.distinct()
.collect(toList());

这个方法的问题在于,传递给map方法的Lambda为每个单词返回了一个String[](String

列表)。因此, map 返回的流实际上是Stream<String[]> 类型的。你真正想要的是用

Stream<String>来表示一个字符流。因此,这是行不通的。

以下是我对这个问题的解法和分步写法,希望能对你有帮助:

对flatMap的说明:这个在这里的主要作用是对流进行扁平化
String ss = "Hello";
 2
 3         String[] aa = ss.split("");
 4
 5         String[] bb = {"H", "e", "l", "l", "o"};
 6
 7
 8         String[] strings = {"Hello", "World"};
 9
10         //Arrays.stream接收一个数组返回一个流
11         List<Stream<String>> streamList = Arrays.asList(strings).stream().
12                 map(str -> str.split("")).
13                 map(str -> Arrays.stream(str)).
14                 collect(Collectors.toList());
15
16         //分步写(map)
17
18         Stream<String[]> stream = Arrays.asList(strings).stream().
19                 map(str -> str.split(""));
20
21         Stream<Stream<String>> streamStream = stream.map(strings1 -> Arrays.stream(strings1));
22         List<Stream<String>> streamList1 = streamStream.collect(Collectors.toList());
23
24
25         List<String> stringList = Arrays.asList(strings).stream().
26                 map(str -> str.split("")).
27                 flatMap(str -> Arrays.stream(str))
28                 .collect(Collectors.toList());
29
30
31         //分步写(流只能消费一次)(flatMap)
32         Stream<String[]> stream1 = Arrays.asList(strings).stream().
33                 map(str -> str.split(""));
34
35         Stream<String> stringStream = stream1.flatMap(strings1 -> Arrays.stream(strings1));
36
37         List<String> stringList1 = stringStream.collect(Collectors.toList());

另一篇转自:jdk8 Stream map和flatMap区别

  • 1.map

  • 将一种类型的值转换为另外一种类型的值。
  • 代码:将List 转换成List
 List<String> collected = Stream.of("a", "b").collect(Collectors.toList());

  List<Integer> figure = collected.stream().map(s -> {
            Integer i;
            switch (s) {
                case "a":
                    i = 1;
                    break;
                case "b":
                    i = 2;
                    break;
                default:
                    i = -1;
                    break;
            }
            return i;
        }).collect(Collectors.toList());
  • 2.flatMap(类似C# AddRange)

  • 将多个Stream连接成一个Stream,这时候不是用新值取代Stream的值,与map有所区别,这是重新生成一个Stream对象取而代之。
   List<Integer> a=new ArrayList<>();
        a.add(1);
        a.add(2);
        List<Integer> b=new ArrayList<>();
        b.add(3);
        b.add(4);
        List<Integer> figures=Stream.of(a,b).flatMap(u->u.stream()).collect(Collectors.toList());
        figures.forEach(f->System.out.println(f));
    • 或者看下面这个例子

    • flatMap方法

      [java] view plain copy

      1. List<String> words = new ArrayList<String>();
      2. words.add("your");
      3. words.add("name");

      4. public static Stream<Character> characterStream(String s){
      5. List<Character> result = new ArrayList<>();
      6. for (char c : s.toCharArray())
      7. result.add(c);
      8. return result.stream();
      9. }
      10. Stream<Stream<Character>> result = words.map(w -> characterStream(w));
      11. Stream<Character> letters = words.flatMap(w -> characterStream(w));

      如果使用的是map方法,返回的是[ ...[‘y‘, ‘o‘, ‘u‘, ‘r‘], [‘n‘, ‘a‘, ‘m‘, ‘e‘]]

      如果使用的是flatMap方法,返回的是[‘y‘, ‘o‘, ‘u‘, ‘r‘, ‘n‘, ‘a‘, ‘m‘, ‘e‘]

      这是map和flatMap的区别

    • [java] view plain copy
          @Test
              public void testMapAndFlatMap() {
                  List<String> words = new ArrayList<String>();
                  words.add("hello");
                  words.add("word");  
      
                  //将words数组中的元素再按照字符拆分,然后字符去重,最终达到["h", "e", "l", "o", "w", "r", "d"]
                  //如果使用map,是达不到直接转化成List<String>的结果
                  List<String> stringList = words.stream()
                          .flatMap(word -> Arrays.stream(word.split("")))
                          .distinct()
                          .collect(Collectors.toList());
                  stringList.forEach(e -> System.out.println(e));
              }

原文地址:https://www.cnblogs.com/lijingran/p/8727507.html

时间: 2024-07-30 10:19:20

java8中stream的map和flatmap的理解的相关文章

Java8中Stream的归约与收集

Java8中Stream的归约与收集 归约 reduce(T identity, BinaryOperator) / reduce(BinaryOperator) --可以将流中元素反复结合起来,得到一个值 public class Employee { private String name; private Integer age; private Double salary; private Status status; public Employee() { super(); } pub

spark RDD 中 transformation的map、flatMap、mapPartitions、glom详解--(视频笔记)

map 通过自定义函数 f:T->u 将元数据T转换为u,不会将split进行合并 flatMap通过自定义函数 f:T->u 进行数据变换,并将拆分后的小集合合并成一个大集合. mapPartitionsIter => iter.filter(_>3)作用于整个分区(例如hbase表等)进行操作 glom将每个分区生成数组,将泛型RDD转换为RDD[Array]

Stream之filter、distinct、skip、map、flatMap、match、find、reduce

一.Stream之filter.distinct.skip: 1 package com.cy.java8; 2 3 import java.util.Arrays; 4 import java.util.List; 5 import java.util.stream.Collectors; 6 7 public class StreamFilter { 8 9 public static void main(String[] args) { 10 List<Integer> list = A

java8中optional和.stream().map()

使用optional的好处:是一个可以包含或不可以包含非空值的容器对象,更加友好的处理程序中的空对象. Optional<T>有方法 isPresent() 和 get() 是用来检查其包含的对象是否为空或不是,然后返回它,如: Optional<SomeType> someValue = someMethod(); if (someValue.isPresent()) { // check someValue.get().someOtherMethod(); // retriev

Java8之Stream/Map

本篇用代码示例结合JDk源码讲了Java8引入的工具接口Stream以及新Map接口提供的常用默认方法.    参考:http://winterbe.com/posts/2014/03/16/java-8-tutorial/ 1.Stream示例 package com.mavsplus.java8.turtorial.streams; import java.util.ArrayList; import java.util.List; import java.util.Optional; im

Spark 中 map 与 flatMap 的区别

通过一个实验来看Spark 中 map 与 flatMap 的区别. 步骤一:将测试数据放到hdfs上面 hadoopdfs -put data1/test1.txt /tmp/test1.txt 该测试数据有两行文本: 步骤二:在Spark中创建一个RDD来读取hdfs文件/tmp/test1.txt 步骤三:查看map函数的返回值 得到map函数返回的RDD: 查看map函数的返回值--文件中的每一行数据返回了一个数组对象 步骤四:查看flatMap函数的返回值 得到flatMap函数返回的

理解Swift中map 和 flatMap对集合的作用

map和flatMap是函数式编程中常见的概念,python等语言中都有.借助于 map和flapMap 函数可以非常轻易地将数组转换成另外一个新数组. map函数可以被数组调用,它接受一个闭包作为參数,作用于数组中的每一个元素.闭包返回一个变换后的元素.接着将全部这些变换后的元素组成一个新的数组. 简单的说. map就是映射函数,把一个集合映射成还有一个集合. Swift的flatMap不easy理解,flatMap非常像map函数,可是它摒弃了那些值为nil的元素. flatMap是在处理一

第88讲:Scala中使用For表达式实现map、flatMap、filter

今天我们来学习一下如何使用for表达式实现map.flatMap以及filter 首先,我们来看下map.map的功能是,传入一个list,通过一个函数f,将list中的元素A变成元素B的过程.最后得到由B形成的列表.这个过程如果由for循环实现的话,如下操作: for(element <- list) yield f(element) 接下来我们看下flatMap.flatMap的功能是,传入一个list,通过一个函数f,将list中的每个元素转换成一个列表,最后返回由这些列表中的所有元素构成

Scala深入浅出实战经典《第88讲:Scala中使用For表达式实现map、flatMap、filter》笔记

简直了....晚上回来突然看到了进巨的原稿,忍不住撸了幅三爷,然后什么都没做就23点了... 第88讲:Scala中使用For表达式实现map.flatMap.filter Goal: For表达式实现map/flatMap/filter Gains: map/flatMap/filter是泛型 More: ...... ------------------------------------------------------------------------------------ 信息来