通俗易懂,java8 .stream().map().collect()用法
生活随笔
收集整理的這篇文章主要介紹了
通俗易懂,java8 .stream().map().collect()用法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
API: https://www.runoob.com/java/java8-streams.html
模板:
mylist.stream().map(myfunction->{return item;}).collect(Collectors.toList());說明:
steam():把一個源數據,可以是集合,數組,I/O channel, 產生器generator 等,轉化成流。
forEach():迭代流中的每個數據。以下代碼片段使用 forEach 輸出了10個隨機數.
Random random = new Random(); random.ints().limit(10).forEach(System.out::println);map():用于映射每個元素到對應的結果。以下代碼片段使用 map 輸出了元素對應的平方數:
List<Integer> numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5); // 獲取對應的平方數 List<Integer> squaresList = numbers.stream().map( i -> i*i).distinct().collect(Collectors.toList());filter():filter 方法用于通過設置的條件過濾出元素。以下代碼片段使用 filter 方法過濾出空字符串:
List<String>strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl"); // 獲取空字符串的數量 int count = strings.stream().filter(string -> string.isEmpty()).count(); limit limit 方法用于獲取指定數量的流。 以下代碼片段使用 limit 方法打印出 10 條數據:Random random = new Random(); random.ints().limit(10).forEach(System.out::println);sorted():用于對流進行排序。以下代碼片段使用 sorted 方法對輸出的 10 個隨機數進行排序:
Random random = new Random(); random.ints().limit(10).sorted().forEach(System.out::println); 并行(parallel)程序 parallelStream 是流并行處理程序的代替方法。以下實例我們使用 parallelStream 來輸出空字符串的數量:List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl"); // 獲取空字符串的數量 int count = strings.parallelStream().filter(string -> string.isEmpty()).count(); 我們可以很容易的在順序運行和并行直接切換。Collectors():類實現了很多歸約操作,例如將流轉換成集合和聚合元素。Collectors 可用于返回列表或字符串:
List<String>strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl"); List<String> filtered = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.toList());System.out.println("篩選列表: " + filtered); String mergedString = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.joining(", ")); System.out.println("合并字符串: " + mergedString);總結
以上是生活随笔為你收集整理的通俗易懂,java8 .stream().map().collect()用法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 别翻了,成员变量和局部变量在多线程中的使
- 下一篇: 【含义解析】%d{yyyy-MM-dd