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


原創:https://blog.csdn.net/az44yao

 

有一個集合:

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







免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM