原創: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 }))
