两个办法的背景

这两个办法看起来做着同样的事件,但实际上又有些不一样。看源码局部是这样的

package java.util.stream;

map()办法

/*** @param <R> The element type of the new stream* @param mapper a <a href="package-summary.html#NonInterference">non-interfering</a>,* <a href="package-summary.html#Statelessness">stateless</a>*               function to apply to each element* @return the new stream*/    <R> Stream<R> map(Function<? super T, ? extends R> mapper);

flatMap()办法

/*** @param <R> The element type of the new stream* @param mapper a <a href="package-summary.html#NonInterference">non-interfering</a>,* <a href="package-summary.html#Statelessness">stateless</a>* function to apply to each element which produces a stream* of new values* @return the new stream*/<R> Stream<R> flatMap(Function<? super T, ? extends Stream<? extends R>> mapper);

Stream map() Method

看源码做揣测,map是一种两头操作,返回的是Stream

代码测试

map()办法

public static void main(String[] args) {        System.out.println("Output with simple list");        List<String> vowels = Arrays.asList("A", "E", "I", "O", "U");        vowels.stream().map(vowel -> vowel.toLowerCase())                .forEach(value -> System.out.println(value));        List<String> haiList = new ArrayList<>();        haiList.add("hello");        haiList.add("hai");        haiList.add("hehe");        haiList.add("hi");        System.out.println("Output with nested List of List<String>");        List<String> welcomeList = new ArrayList<>();        welcomeList.add("You got it");        welcomeList.add("Don't mention it");        welcomeList.add("No worries.");        welcomeList.add("Not a problem");        List<List<String>> nestedList = Arrays.asList(haiList, welcomeList);        nestedList.stream().map(list -> {            return list.stream().map(value -> value.toUpperCase());        }).forEach(value -> System.out.println(value));    }

Output

Output with simple listaeiouOutput with nested List of List<String>java.util.stream.ReferencePipeline$3@3b9a45b3java.util.stream.ReferencePipeline$3@7699a589

flatMap()办法

public static void main(String[] args) {        List<String> haiList = new ArrayList<>();        haiList.add("hello");        haiList.add("hai");        haiList.add("hehe");        haiList.add("hi");        System.out.println("Output with nested List of List<String>");        List<String> welcomeList = new ArrayList<>();        welcomeList.add("You got it");        welcomeList.add("Don't mention it");        welcomeList.add("No worries.");        welcomeList.add("Not a problem");        List<List<String>> nestedList = Arrays.asList(haiList, welcomeList);        nestedList.stream().flatMap(                list -> list.stream())                .map(value -> value.toUpperCase())                .forEach(value -> System.out.println(value));    }

Output

Output with nested List of List<String>HELLOHAIHEHEHIYOU GOT ITDON'T MENTION ITNO WORRIES.NOT A PROBLEM

Java 8 map() vs flatMap()

  • map()和flatMap()办法都能够利用于Stream <T>和Optional <T>。 并且都返回Stream <R>或Optional <U>。
  • 区别在于,映射操作为每个输出值生成一个输入值,而flatMap操作为每个输出值生成任意数量(零个或多个)的值。 在flatMap()中,每个输出始终是一个汇合,能够是List或Set或Map。 映射操作采纳一个函数,该函数将为输出流中的每个值调用,并生成一个后果值,该后果值将发送到输入流。 flatMap操作采纳的性能在概念上想耗费一个值并产生任意数量的值。 然而,在Java中,办法返回任意数量的值很麻烦,因为办法只能返回零或一个值。

代码

 public static void main(String[] args) {        List<Stream> together = Stream.of(Arrays.asList(1, 2), Arrays.asList(3, 4)) // Stream of List<Integer>                .map(List::stream)                .collect(Collectors.toList());        System.out.println("Output with map() -> "+together);        List<Integer> togetherFlatMap = Stream.of(Arrays.asList(1, 2), Arrays.asList(3, 4)) // Stream of List<Integer>                .flatMap(List::stream)                .map(integer -> integer + 1)                .collect(Collectors.toList());        System.out.println("Output with flatMap() -> "+togetherFlatMap);    }

Output

Output with map() -> [java.util.stream.ReferencePipeline$Head@16b98e56, java.util.stream.ReferencePipeline$Head@7ef20235]Output with flatMap() -> [2, 3, 4, 5]