Java 8之流Stream
阿新 • • 發佈:2018-12-19
public void testJava8() { // Collectors 類實現了很多歸約操作,例如將流轉換成集合和聚合元素。Collectors 可用於返回列表或字串: List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd", "", "jkl"); List<String> filtered = strings.stream().filter(s -> !s.isEmpty()).collect(Collectors.toList()); String merged = strings.stream().filter(s -> !s.isEmpty()).collect(Collectors.joining(", ")); System.out.println("篩選列表:" + filtered); System.out.println("合併字串:" + merged); // stream 提供了新的方法 'forEach' 來迭代流中的每個資料。以下程式碼片段使用 forEach 輸出了10個隨機數: // limit 方法用於獲取指定數量的流。 // sorted 方法用於對流進行排序。 Random random = new Random(); random.ints().limit(10).sorted().forEach(System.out::println); // map 方法用於對映每個元素到對應的結果,以下程式碼片段使用 map 輸出了元素對應的平方數: // distinct 去掉重複 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()); System.out.println(squaresList); // filter 方法用於通過設定的條件過濾出元素。以下程式碼片段使用 filter 方法過濾出空字串: List<String> str = Arrays.asList("ab", "", "cd", "", "", "ef"); long count = str.stream().filter(s -> s.isEmpty()).count(); System.out.println("count:" + count); // parallelStream 是流並行處理程式的代替方法。以下例項我們使用 parallelStream 來輸出空字串的數量: List<String> strs = Arrays.asList("abc", "", "cde", "fgh", "ijk", "", "s"); long count1 = strs.parallelStream().filter(s -> s.isEmpty()).count(); System.out.println("count1:" + count1); // 一些產生統計結果的收集器也非常有用。它們主要用於int、double、long等基本型別上,它們可以用來產生類似如下的統計結果。 List<Integer> nums = Arrays.asList(1, 2, 3, 4, 6, 3, 5, 5, 9); IntSummaryStatistics num = nums.stream().mapToInt((x) -> x).summaryStatistics(); System.out.println("最大值:" + num.getMax()); System.out.println("最小值:" + num.getMin()); System.out.println("平均值:" + num.getAverage()); System.out.println("求總和:" + num.getSum()); System.out.println("總個數:" + num.getCount()); }