1. 程式人生 > 其它 >java8 stream().map().collect()用法

java8 stream().map().collect()用法

有一個集合:

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()方法的使用示例:

再看幾個例子:陣列字母小寫變大寫
List<String> list= Arrays.asList("a", "b", "c", "d");

List<String> collect =list.stream().map(String::toUpperCase).collect(Collectors.toList());
System.out.println(collect); //[A, B, C, D]

陣列所有元素,按某種規律計算:
List<Integer> num = Arrays.asList(1,2,3,4,5);
List<Integer> collect1 = num.stream().map(n -> n * 2).collect(Collectors.toList());
System.out.println(collect1); //[2, 4, 6, 8, 10]

Collectors.toList()的理解

https://www.cnblogs.com/zhvip/p/12839019.html

Collectors.toList()用來結束Stream流。

複製程式碼

    public static void main(String[] args) {

        List<String> list = Arrays.asList("hello","world","stream");
        list.stream().map(item->item+item).collect(Collectors.toList()).forEach(System.out::println);
        list.stream().map(item->item+item).collect(
                ArrayList::new,
                (list1,value )-> list1.add(value),
                (list1 ,list2)-> list1.addAll(list2)
                ).forEach(System.out::println);

    }

複製程式碼

    <R> R collect(Supplier<R> supplier,
                  BiConsumer<R, ? super T> accumulator,
                  BiConsumer<R, R> combiner);

從文件上我們可以知道,collect()方法接收三個函式式介面

  • supplier表示要返回的型別,Supplier<R> supplier不接收引數,返回一個型別,什麼型別,這裡是ArrayList型別,所以是ArrayList::new
  • BiConsumer<R, ? super T> accumulator接收兩個引數,一個是返回結果(ArrayList),一個是stream中的元素,會遍歷每一個元素,這裡要做的是把遍歷的每一個元素新增到要返回的ArrayList中,所以第二個引數(list1,value )-> list1.add(value),
  • BiConsumer<R, R> combiner接收兩個引數,一個是返回結果,一個是遍歷結束後得到的結果,這裡要把遍歷結束後得到的list新增到要返回的list中去,所以第三個引數是,(list1 ,list2)-> list1.addAll(list2)
    public static <T>
    Collector<T, ?, List<T>> toList() {
        return new CollectorImpl<>((Supplier<List<T>>) ArrayList::new, List::add,
                                   (left, right) -> { left.addAll(right); return left; },
                                   CH_ID);
    }

我們可以看到,Collectors.toList()預設也是這麼實現的,所以他們兩種寫法是等價的。

kotlin 程式碼 直接用

 whellpicker1.setData(mPresenter.dataList.map({ it.childname }))