這篇文章給大家分享的是有關java8 stream flatMap流的扁平化是什么的內容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
創新互聯于2013年創立,是專業互聯網技術服務公司,擁有項目網站設計、網站建設網站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元平遠做網站,已為上家服務,為平遠各地企業和個人服務,聯系電話:13518219792概念:
Steam 是Java8 提出的一個新概念,不是輸入輸出的 Stream 流,而是一種用函數式編程方式在集合類上進行復雜操作的工具。簡而言之,是以內部迭代的方式處理集合數據的操作,內部迭代可以將更多的控制權交給集合類。Stream 和 Iterator 的功能類似,只是 Iterator 是以外部迭代的形式處理集合數據的操作。
在Java8以前,對集合的操作需要寫出處理的過程,如在集合中篩選出滿足條件的數據,需要一 一遍歷集合中的每個元素,再把每個元素逐一判斷是否滿足條件,最后將滿足條件的元素保存返回。而Stream 對集合篩選的操作提供了一種更為便捷的操作,只需將實現函數接口的篩選條件作為參數傳遞進來,Stream會自行操作并將合適的元素同樣以stream 的方式返回,最后進行接收即可。
2種操作:
1.intermediate operation 中間操作:中間操作的結果是刻畫、描述了一個Stream,并沒有產生一個新集合,這種操作也叫做惰性求值方法。
2.terminal operation 終止操作:最終會從Stream中得到值。
如何區分這2種操作呢?可以根據操作的返回值類型判斷,如果返回值是Stream,則該操作是中間操作,如果返回值是其他值或者為空,則該操作是終止操作。
flatMap 中間操作:
可用 Stream 替換值,并將多個 Stream 流合并成一個 Stream 流。
將含有一串數字的兩個流合并為一個流,
@Test public void flapMapTest() { List<Integer> list = (List<Integer>) Stream.of(Arrays.asList(1, 2, 3, 4, 5, 6), Arrays.asList(8, 9, 10, 11, 12)) .flatMap(test -> test.stream()).collect(Collectors.toList()); for (int i = 0, length = list.size(); i < length; i++) { System.out.println(list.get(i)); } }
本文標題:java8streamflatMap流的扁平化是什么-創新互聯
文章來源:http://vcdvsql.cn/article18/hcgdp.html
成都網站建設公司_創新互聯,為您提供外貿建站、外貿網站建設、定制開發、電子商務、做網站、動態網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯