1. 程式人生 > >Java 8之流Stream

Java 8之流Stream

    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());
    }