JAVA8 Stream
- java8API添加了一個新的抽象概念Stream,可以讓你以一種聲明的方式處理數據。
- Stream使用一種類似SQL語句從數據庫查詢數據的直觀方式來提供一種對Java集合運算和表達的高階抽象。
- Stream API可以極大提高Java程序員的生產力,讓程序員寫出高效率、簡潔、干凈的代碼。
- 這種風格將要處理的元素集合看作一種流,流在管道中傳輸,並且可以在管道的節點上進行處理,比如篩選、排序、耦合等。
- 元素流在管道中經過中間操作(intermediate operation)的處理,最后由最終操作(terminal operation)得到前面處理的結果。
什么是 Stream?
Stream(流)是一個來自數據源的元素隊列並支持聚合操作 元素是特定類型的對象,形成一個隊列。 Java中的Stream並不會存儲元素,而是按需計算。 數據源 流的來源。 可以是集合,數組,I/O channel, 產生器generator 等。 聚合操作 類似SQL語句一樣的操作, 比如filter, map, reduce, find, match, sorted等。 和以前的Collection操作不同, Stream操作還有兩個基礎的特征: Pipelining: 中間操作都會返回流對象本身。 這樣多個操作可以串聯成一個管道, 如同流式風格(fluent style)。 這樣做可以對操作進行優化, 比如延遲執行(laziness)和短路( short-circuiting)。 內部迭代: 以前對集合遍歷都是通過Iterator或者For-Each的方式, 顯式的在集合外部進行迭代, 這叫做外部迭代。 Stream提供了內部迭代的方式, 通過訪問者模式(Visitor)實現。
有一個集合:
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]