您好,登錄后才能下訂單哦!
前言
只有光頭才能變強。
相信也有不少的同學想要知道:Lambda表達式在工作中哪個場景會用得比較多?跟Lambda搭邊的,使用 Stream流會比較多
一般人第一次看Stream流的代碼,都會有點看不懂(它的代碼看起來好像就不是寫Java一樣.),希望這篇文章能帶大家入個門
一、體驗Stream流
大家在自學時,大多數會學過一個程序:算出從數組元素的和,當時我們是怎么寫的?一般來說是這樣的:
publicstaticvoidmain(String[]args){int[]nums={1,2,3};intsum=0;for(inti:nums){sum+=i;}System.out.println("結果為:"+sum);}
如果我們使用Stream流的話,可以這樣:
publicstaticvoidmain(String[]args){int[]nums={1,2,3};intsum2=IntStream.of(nums).sum();System.out.println("結果為:"+sum2);}
從 代碼量上可以明顯看出,用Stream流的方式會少一些。
我理解的Stream流編程就是: 某些場景會經常用到操作(求和/去重/過濾….等等),已經封裝好API給你了,你自己別寫了,調我給你提供的API就好了。
1.1 支持并發
回到我們最原始的代碼:
publicstaticvoidmain(String[]args){int[]nums={1,2,3};intsum=0;for(inti:nums){sum+=i;}System.out.println("結果為:"+sum);}
如果我們想要for循環的內部支持并發的話,顯然不太好去寫。但使用Stream流的方式, 調用一個方法就可以支持并發(parallel):
publicstaticvoidmain(String[]args){int[]nums={1,2,3};intsum2=IntStream.of(nums).parallel().sum();System.out.println("結果為:"+sum2);}
優點:調API肯定是比自己寫的代碼量要少。
缺點:不方便調試
為什么要使用Stream流在我看來就是以上兩個原因:
二、如何使用Stream流?
Stream繼承結構圖
使用Stream流分為三步:
三步走
2.1 創建流
創建流我們最常用的就是 從集合中創建出流
/***返回的都是流對象*@paramargs*/publicstaticvoidmain(String[]args){List<String>list=newArrayList<>();//從集合創建Stream<String>stream=list.stream();Stream<String>stream1=list.parallelStream();//從數組創建IntStreamstream2=Arrays.stream(newint[]{2,3,5});//創建數字流IntStreamintStream=IntStream.of(1,2,3);//使用random創建IntStreamlimit=newRandom().ints().limit(10);}
2.2 執行中間操作
怎么理解中間操作?意思是這樣的:在上面我們已經能創建出Stream了,我們是對 Stream進行操作,對Stream操作返回完返回的還是Stream,那么我們稱這個操作為中間操作。
中間操作 解釋
比如,我們現在有個字符串my name is 007,代碼如下:
Stringstr="mynameis007";Stream.of(str.split("")).filter(s->s.length()>2).map(s->s.length()).forEach(System.out::println);
分解:
1、從字符串數組創建出流對象:
Stream<String>split=Stream.of(str.split(""));
2、通過流對象的API執行中間操作(filter),返回的還是流對象:
Stream<String>filterStream=split.filter(s->s.length()>2);
3、通過返回的流對象再執行中間操作(map),返回的還是流對象:
Stream<Integer>integerStream=filterStream.map(s->s.length());
因為中間操作返回的都是 流對象,所以我們可以 鏈式調用。
注意:Stream上的操作并不會立即執行,只有等到用戶真正需要結果的時候才會執行( 惰性求值)。
比如說,peek()是一個中間操作,返回的是Stream流對象,只要它不執行最終的操作,這個Stream是不會執行的。
Stringstr="mynameis007";Stream.of(str.split("")).peek(System.out::println);//不會有信息打印
2.3 執行最終操作
最終操作返回的不再是Stream對象, 調用了最終操作的方法,Stream才會執行。還是以上面的例子為例:
Stringstr="mynameis007";Stream.of(str.split("")).peek(System.out::println).forEach(System.out::println)
這次我們加入了最終操作,所以這次的Stream流會被執行,由于中間操作和最終操作都是執行打印,所以會看到兩次打印:
結果圖
至于中間操作和最終操作怎么區分,我們以 返回值來看就行了。中間操作返回的是Stream實例對象,最終操作返回的不是Stream實例對象:
Stream接口的方法
最后
這篇文章主要跟大家一起初步認識一下Stream流,至于中間操作、最終操作的API講解我就不寫了(網上的教程也很多)
使用Stream的原因我認為有兩個:
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。