日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

stream of java_Java 8 新特性-Stream更优雅的处理集合入门

發布時間:2024/9/27 java 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 stream of java_Java 8 新特性-Stream更优雅的处理集合入门 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Java 8 新特性之——Stream

一. 簡單介紹

Stream是Java 8提出了的一種新的對集合對象功能的增強。它集合Lambda表達式,對集合提供了一些非常便利,高效的操作,使得代碼具有非常高的可讀性,優雅性!!舉個例子來說,它就像一個流水線操作,對輸入流水線的東西(水果)進行一系列加工處理,最后獲取到我們需要的某種特殊的水果(沒有洗過的蘋果)。

Stream提供了對集合的便捷化處理方式

聲明式編程的思想

代碼更加優雅,簡潔,不信往下看→_→

來個例子來看看Stream風格

上海從今年7月1號開始,進行了史無前例的垃圾分類,先看個圖圖,下圖是上海最近流行的挎包(捂臉笑哭),怕不怕,哈哈。

閑話不多說,進入正題,現在需要將一堆垃圾List garbages分類處理。

使用了Stream的代碼風格

//有一堆沒分類的垃圾

List garbage = new ArrayList<>();

//通過 Java 8 提供的流優雅的處理下,瞧好嘍

List 干垃圾 = garbage.stream() //1. 垃圾倒出來,放到流水線

.filter(x -> "挑出有害垃圾") //2. 挑出有害垃圾

.filter(x -> "挑出可回收垃圾") //3. 挑出可回收垃圾

.filter(x -> "挑出有害垃圾") //4. 挑出有害垃圾

.collect(Collectors.toList()); //5. 把剩下的干垃圾裝到干垃圾桶

/** 上面是不是非常優雅呢 **/

二. Stream 的操作流程

Stream的所有操作分為三個階段,【創建】>> 【中間操作】>> 【終端操作】

1. Stream 的【創建】

方式一

list.stream()

//通過List集合創建

List list = Arrays.asList("1", "2", "3");

//list.stream()

Stream stream = list.stream();

方式二

Stream.of()

//直接通過指定的元素創建

Stream stream = Stream.of("1", "2", "3");

//通過數組Array

String[] arrays = {"a", "b", "c"};

Stream stream = Stream.of(arrays);

//和上面區別不大

Stream stream1 = Arrays.stream(arrays);

其他

數值流的操作

對于基本數值型,目前有三種對應的包裝類型 Stream:

IntStream.of(new int[]{1, 2, 3}).forEach(System.out::println);

IntStream.range(1, 3).forEach(System.out::println);

IntStream.rangeClosed(1, 3).forEach(System.out::println);

2. Stream的流水線操作【中間操作】

下面式常用的中間操作

Stream Operation

Goal

Input

filter

filter 方法用于通過設置的條件過濾出元素。

條件(返回布爾值)Predicate

map

map 方法用于映射每個元素到對應的結果

可以是一個功能 Function

limit

limit 方法用于獲取指定數量的流

int值

sorted

sorted 方法用于對流進行排序

Comparator

distinct

去除重復

--

parallel

parallelStream 是流并行處理程序的代替方法

--

filter統計空字符串的個數

Liststrings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");

// 獲取空字符串的數量

int count = strings.stream().filter(string -> string.isEmpty()).count()

map 使用 map 輸出了元素對應的平方數

List numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);

// 獲取對應的平方數

List squaresList = numbers.stream().map( i -> i*i).distinct().collect(Collectors.toList());

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

distinct使用 distinct 對元素進行去重

List numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);

numbers.stream().distinct().forEach(System.out::println);

parallel 使用 parallelStream 來輸出空字符串的數量

List strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");

// 獲取空字符串的數量

int count = strings.parallelStream().filter(string -> string.isEmpty()).count();

3. 【終端操作】

Stream Operation

Goal

Input Or Output

forEach

遍歷元素

其他操作

count

統計元素個數

--

collect

聚合操作

--

forEach遍歷打印

Stream.of("a", "b", "c").forEach(System.out::println);

count統計'a'的數量

long count = Stream.of("a", "b", "c", "a").filter(x -> "a".equals(x)).count();//2

collect聚合

// 1. 聚合轉成List

List list1 = stream.collect(Collectors.toList());

List list2 = stream.collect(Collectors.toCollection(ArrayList::new));

// 2. 聚合轉成Set

Set set1 = stream.collect(Collectors.toSet());

Stack stack1 = stream.collect(Collectors.toCollection(Stack::new));

// 3. 聚合轉成String

String str = stream.collect(Collectors.joining()).toString();

// 4. ···其他

1. 循環list中的所有元素然后刪除重復

/**

* 循環list中的所有元素然后刪除重復

*

* @param list 待去重的list

* @return 去重后的list

*/

public static List removeDuplicate(List list) {

for (int i = 0; i < list.size() - 1; i++) {

for (int j = list.size() - 1; j > i; j--) {

if (list.get(j).getStaffNo().equals(list.get(i).getStaffNo())) {

list.remove(j);

}

}

}

return list;

}

2. 利用java8新特性去重參考原文鏈接

//list集合中根據userName去重

List lists = lists.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(User::getUsrName))), ArrayList::new));

3. 排序 參考原文鏈接

List list = promotionBasicDao.

list(new WherePrams().orderBy("create_time desc"));

list = list.stream().sorted(Comparator.comparing(PromotionForHomeDto::getCreateTime))

.collect(Collectors.toList());

4. 分組

把一個集合分組(原來集合里的數據順序會打亂重排列)會默認使用HashMap

List stus...;

Map> group = stus.stream().collect(Collectors.groupingBy(Student::getStudentNo));

解決辦法,使用LinkedHashMap分組按之前List的順序

List stus...;

Map> group = stus.stream().collect(Collectors.groupingBy(Student::getStudentNo, LinkedHashMap::new, Collectors.toList()));

實測例子:

public static void main(String[] args) {

List lists = new ArrayList<>();

lists.add("A");

lists.add("D");

lists.add("C");

lists.add("B");

lists.add("A");

System.out.println("原始列表數據 :" + lists);

Map> collect1 = lists.stream().collect(Collectors.groupingBy(x -> x));

System.out.println("JAVA Stream分組處理完,默認處理:" + collect1);

Map> collect = lists.stream().collect(Collectors.groupingBy(x -> x, LinkedHashMap::new, Collectors.toList()));

System.out.println("JAVA Stream分組處理完,LinkedHashMap:" + collect);

}

4. List轉Map

/*

* List -> Map

* 需要注意的是:

* toMap 如果集合對象有重復的key,會報錯Duplicate key ....

* apple1,apple12的id都為1。

* 可以用 (o1,o2)->o1 來設置,如果有重復的key,則保留key1,舍棄key2

*/

Map collect2 = lists.stream().collect(Collectors.toMap(String::toLowerCase, x -> x + "測試", (o1, x2) -> o1));

System.out.println("List轉Map:" + collect2);

三. 簡單說下聲明式編程

小故事:早上剛上班,經理找到大胖說:“大胖啊,咱們下去去聚餐,軟件園旁邊有好幾家不錯的餐館,如巫山烤魚、海底撈、大鴨梨,你到大眾點評調查一下,也問問去過的同事,看看哪家的口碑好。我們有14個人,預定一張大桌子,然后用滴滴約4輛車,每輛車坐3~4人,我們會在11點半出發”。

如果經理是程序員,大胖是計算機,這就是典型的命令式編程。

實際上,現實中一般是經理對大胖說:“大胖啊,我給你交代一件事,咱們下午要聚餐,你在軟件園旁邊找一家合適的餐館,我們有14個人,11點半出發”。這種就是聲明式編程

1. 聲明式編程最知名的就是我們都熟悉的SQL

SELECT stu.id, stu.name, ss.score

FROM student stu, student_score ss

WHERE stu.id = ss.id

AND ss.score > 80

2. 用Java也來舉個例子

有一個學生列表,計算出年齡小于18歲的學生數量

傳統命令式編程

//聲明一個計數器,遍歷學生集合,如果學生年齡小于18歲,計數器+1

int count = 0;

Iterator iter = students.iterator();

while(iter.hasNext()) {

Student s = iter.next();

if (s.getAge < 18) {

count++;

}

}

聲明式編程

//過濾學生構成的流(Stream),只把年齡小于18歲的留下,然后做個統計。

int count = students.stream()

.filter(s -> s.getAge() < 18)

.count();

聲明式編程也是一種高度的抽象,我只告訴你我要干什么,至于怎么干,我Don't care

總結

以上是生活随笔為你收集整理的stream of java_Java 8 新特性-Stream更优雅的处理集合入门的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。