關(guān)于Java8中map()和flatMap()的一些事
兩個方法的背景
這兩個方法看起來做著同樣的事情,但實(shí)際上又有些不一樣。看源碼部分是這樣的
package java.util.stream;
map()方法
/** * @param <R> The element type of the new stream * @param mapper a <a href="package-summary.html#NonInterference" rel="external nofollow" rel="external nofollow" >non-interfering</a>, * <a href="package-summary.html#Statelessness" rel="external nofollow" rel="external nofollow" >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" rel="external nofollow" rel="external nofollow" >non-interfering</a>, * <a href="package-summary.html#Statelessness" rel="external nofollow" rel="external nofollow" >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 list a e i o u Output with nested List of List<String> java.util.stream.ReferencePipeline$3@3b9a45b3 java.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> HELLO HAI HEHE HI YOU GOT IT DON'T MENTION IT NO WORRIES. NOT A PROBLEM
Java 8 map() vs flatMap()
- map()和flatMap()方法都可以應(yīng)用于Stream <T>和Optional <T>。 并且都返回Stream <R>或Optional <U>。
- 區(qū)別在于,映射操作為每個輸入值生成一個輸出值,而flatMap操作為每個輸入值生成任意數(shù)量(零個或多個)的值。 在flatMap()中,每個輸入始終是一個集合,可以是List或Set或Map。 映射操作采用一個函數(shù),該函數(shù)將為輸入流中的每個值調(diào)用,并生成一個結(jié)果值,該結(jié)果值將發(fā)送到輸出流。 flatMap操作采用的功能在概念上想消耗一個值并產(chǎn)生任意數(shù)量的值。 但是,在Java中,方法返回任意數(shù)量的值很麻煩,因?yàn)榉椒ㄖ荒芊祷亓慊蛞粋€值。
代碼
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]
總結(jié)
到此這篇關(guān)于關(guān)于Java8中map()和flatMap()的文章就介紹到這了,更多相關(guān)Java8中map()和flatMap()內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MybatisPlus自動填充創(chuàng)建(更新)時間問題
在開發(fā)數(shù)據(jù)庫相關(guān)應(yīng)用時,手動設(shè)置創(chuàng)建和更新時間會導(dǎo)致代碼冗余,MybatisPlus提供了自動填充功能,通過實(shí)現(xiàn)MetaObjectHandler接口并重寫insertFill、updateFill方法,可以自動維護(hù)創(chuàng)建時間、更新時間等字段,極大簡化了代碼,這不僅提高了開發(fā)效率,也保證了數(shù)據(jù)的可追溯性2024-09-09maven項(xiàng)目在實(shí)踐中的構(gòu)建管理之路的方法
這篇文章主要介紹了maven項(xiàng)目在實(shí)踐中的構(gòu)建管理之路的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05Java實(shí)現(xiàn)Dijkstra算法的示例代碼
Dijkstra(迪杰斯特拉)算法是典型的單源最短路徑算法,用于計(jì)算一個節(jié)點(diǎn)到其他所有節(jié)點(diǎn)的最短路徑。本文主要介紹了實(shí)現(xiàn)這一算法的Java代碼,需要的可以參考一下2022-07-07深入探究Java中的HashMap為什么會產(chǎn)生死循環(huán)
HashMap?死循環(huán)發(fā)生在?JDK?1.8?之前的版本中,這篇文章主要來和大家深入探究一下為什么Java中HashMap會產(chǎn)生死循環(huán),感興趣的小伙伴可以了解一下2023-05-05spring boot整合CAS Client實(shí)現(xiàn)單點(diǎn)登陸驗(yàn)證的示例
本篇文章主要介紹了spring boot整合CAS Client實(shí)現(xiàn)單點(diǎn)登陸驗(yàn)證的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-01-01