java8 .stream().map().collect()

steam():把一個源數據,能夠是集合,數組,I/O channel, 產生器generator 等,轉化成流。html

mylist.stream()
	.map(myfunction->{
		return item;
	}).collect(Collectors.toList());

forEach():迭代流中的每一個數據。如下代碼片斷使用 forEach 輸出了10個隨機數.數組



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);https://www.cnblogs.com/HowieYuan/p/9394552.html原文連接:https://blog.csdn.net/shine_guo_star/article/details/94383319Random random = new Random(); random.ints().limit(10).forEach(System.out::println);
相關文章
相關標籤/搜索