Java8 stream map collect foreach

例如有一個集合:

List<User> users = getList(); //從數據庫查詢的用戶集合

現在想獲取User的身份證號碼;在後續的邏輯處理中要用;

常用的方法我們大家都知道,用for循環

List<String> idcards=new ArrayList<String>();//定義一個集合來裝身份證號碼

for(int i=0;i<users.size();i++){

  idcards.add(users.get(i).getIdcard());

}

這種方法要寫好幾行代碼,有沒有簡單點的,有,java8 API能一行搞定:

List<String> idcards= users.stream().map(User::getIdcard).collect(Collectors.toList())

解釋下一這行代碼:

users:一個實體類的集合,類型爲List<User>
User:實體類
getIdcard:實體類中的get方法,爲獲取User的idcard

stream()優點

無存儲。stream不是一種數據結構,它只是某種數據源的一個視圖,數據源可以是一個數組,Java容器或I/O channel等。
爲函數式編程而生。對stream的任何修改都不會修改背後的數據源,比如對stream執行過濾操作並不會刪除被過濾的元素,而是會產生一個不包含被過濾元素的新stream。
惰式執行。stream上的操作並不會立即執行,只有等到用戶真正需要結果的時候纔會執行。
可消費性。stream只能被“消費”一次,一旦遍歷過就會失效,就像容器的迭代器那樣,想要再次遍歷必須重新生成。
stream().map()方法的使用示例:

public static void main(String[] args){
    //toUpper轉大寫
    List<String> list = Arrays.asList("a","b","c");
    List<String> list1 = list.stream().map(String::toUpperCase).collect(Collectors.toList());
    System.out.println(list1);//[A, B, C]

    //某些計算
    List<Integer> num = Arrays.asList(1,2,3,4);
    List<Integer> num1 = num.stream().map(n->n*2).collect(Collectors.toList());
    System.out.println(num1);//[2, 4, 6, 8]
    List<Integer> num2 = num.stream().map(n->n*2).map(n->n-1).collect(Collectors.toList());
    System.out.println(num2);//1, 3, 5, 7]

    //forEach
    Stream<String> stream = Stream.of("a","b","c");
    stream.map(String::toUpperCase).forEach(System.out::println);//A \r\n B \r\n C
}

stream.map和stream.foreach區別

map

<R> Stream<R> map(Function<? super T, ? extends R> mapper)

map 方法接收一個功能型接口,功能型接口接收一個參數,返回一個值。map 方法的用途是將舊數據轉換後變爲新數據,是一種 1:1 的映射,每個輸入元素按照規則轉換成另一個元素。

foreach

void forEach(Consumer<? super T> action)

forEach 接收一個 Consumer 接口。它只接收不參數,沒有返回值。然後在 Stream 的每一個元素上執行該表達式,類似加強for()語句

filter

Stream<T> filter(Predicate<? super T> predicate)

返回由此流的元素組成的流,該流匹配給定的謂詞。例如:

stream.filter(e->e != null)

 

 參考:https://www.cnblogs.com/ngy0217/p/11080840.html

https://blog.csdn.net/baidu_37107022/article/details/78568472

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章