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