dk8引進來的lambda語法是新語法,里面融進了python和c#的部分語法,stream()函數是主要用於集合而言的,對於數組就沒效果
生成流函數
把集合裝成流,可以多次使用這個集合,但是不轉換流的話,只能用一次,這就是轉換成流的好處
stream() − 為集合創建串行流。
parallelStream() − 為集合創建並行流。
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl"); List<String> filtered = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.toList());
forEach
用jdk8來遍歷集合效果很快,代碼如下:
List<String> list =Arrays.asList("a","ad","dr"); list.stream().forEach(System.out::println); //或者如下也可以 list.stream().forEach(a -> System.out.println(a)); //或者不創建流也可以直接使用函數 list.forEach(System.out::println); //或者 list.forEach(a -> System.out.println(a));
limit
主要用來限制顯示的量:eg:
//該random函數若是不傳遞參數,那么就采用當前時間的毫秒數當做種子數,若是傳遞了參數,就用傳遞的數字作為種子數了,但是這樣的話,生成的隨機數就是偽隨機數,雖然隨機,但是點幾次,都基本一樣,因為傳入的種子數限制了函數的選擇性 Random random = new Random(); //受到limit限制,只會隨機顯示10個數字,因為沒有傳遞參數,那么每次點擊都會不一樣,否則,若傳遞了種子數,點擊幾次都一樣 random.ints().limit(10).forEach(System.out::println); //像下面的都一樣 Random random = new Random(10);//傳遞了種子數 random.ints().limit(10).forEach(System.out::println);
map函數
主要用來對傳入的參數進行邏輯處理,例如:
//用數組來轉換集合 List<Integer> list = Arrays.asList(9,3,3); //distinct()函數,是去重復函數 list = list.stream().distinct().map(i -> i*i).collect(Collectors.toList()); //打印輸出list list.forEach(System.out::println);
Filter函數
用來過濾所需要的數據
List<String> list = Arrays.asList("1","sd"); list = list.stream().filter(i -> !i.isEmpty()).collect(Collectors.toList());
Collectors函數
可以集合成所需要的集合類型
List<String> list =Arrays.toList("asd","dsg"); //把list集合轉換成帶逗號“,”的字符串 String str=list.stream().filter(a -> !a.isEmpty()).collect(Collectors.joining(",")); //把得到的字符串轉換為了數組了 String[] split = str.split(",");
統計函數
用來統計數組集合的最大最小平均總和的各個值
List<Integer> list = Arrays.asList(12,34,23,12,3,34); IntSummaryStatistics stats= list.stream().mapToInt(x -> x).summaryStatistics(); //最大值 stats.getMax(); //最小值 stats.getMin(); //平均值 stats.getAverage(); //總數 stats.getCount(); //總和 stats.getSum();