您好,登錄后才能下訂單哦!
這篇文章主要講解了如何使用Java 8 Stream和peek,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
簡介
java 8 stream作為流式操作有兩種操作類型,中間操作和終止操作。這兩種有什么區別呢?
我們看一個peek的例子:
Stream<String> stream = Stream.of("one", "two", "three","four");
stream.peek(System.out::println);
上面的例子中,我們的本意是打印出Stream的值,但實際上沒有任何輸出。
為什么呢?
中間操作和終止操作
一個java 8的stream是由三部分組成的。數據源,零個或一個或多個中間操作,一個或零個終止操作。
中間操作是對數據的加工,注意,中間操作是lazy操作,并不會立馬啟動,需要等待終止操作才會執行。
終止操作是stream的啟動操作,只有加上終止操作,stream才會真正的開始執行。
所以,問題解決了,peek是一個中間操作,所以上面的例子沒有任何輸出。
peek
我們看下peek的文檔說明:peek主要被用在debug用途。
我們看下debug用途的使用:
Stream.of("one", "two", "three","four").filter(e -> e.length() > 3) .peek(e -> System.out.println("Filtered value: " + e)) .map(String::toUpperCase) .peek(e -> System.out.println("Mapped value: " + e)) .collect(Collectors.toList());
上面的例子輸出:
Filtered value: three
Mapped value: THREE
Filtered value: four
Mapped value: FOUR
上面的例子我們輸出了stream的中間值,方便我們的調試。
為什么只作為debug使用呢?我們再看一個例子:
Stream.of("one", "two", "three","four").peek(u -> u.toUpperCase())
.forEach(System.out::println);
上面的例子我們使用peek將element轉換成為upper case。然后輸出:
one
two
three
four
可以看到stream中的元素并沒有被轉換成大寫格式。
再看一個map的對比:
Stream.of("one", "two", "three","four").map(u -> u.toUpperCase())
.forEach(System.out::println);
輸出:
ONE
TWO
THREE
FOUR
可以看到map是真正的對元素進行了轉換。
當然peek也有例外,假如我們Stream里面是一個對象會怎么樣?
@Data @AllArgsConstructor static class User{ private String name; }
List<User> userList=Stream.of(new User("a"),new User("b"),new User("c")).peek(u->u.setName("kkk")).collect(Collectors.toList()); log.info("{}",userList);
輸出結果:
10:25:59.784 [main] INFO com.flydean.PeekUsage - [PeekUsage.User(name=kkk), PeekUsage.User(name=kkk), PeekUsage.User(name=kkk)]
我們看到如果是對象的話,實際的結果會被改變。
為什么peek和map有這樣的區別呢?
我們看下peek和map的定義:
Stream<T> peek(Consumer<? super T> action)
<R> Stream<R> map(Function<? super T, ? extends R> mapper);
peek接收一個Consumer,而map接收一個Function。
Consumer是沒有返回值的,它只是對Stream中的元素進行某些操作,但是操作之后的數據并不返回到Stream中,所以Stream中的元素還是原來的元素。
而Function是有返回值的,這意味著對于Stream的元素的所有操作都會作為新的結果返回到Stream中。
這就是為什么peek String不會發生變化而peek Object會發送變化的原因。
看完上述內容,是不是對如何使用Java 8 Stream和peek有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。