學(xué)習(xí)札記-Java8系列-9-再次理解Stream
Stream的定義
上一篇我們已經(jīng)初步體驗(yàn)了Stream的使用书在,那么,Stream到底是什么呢当叭?簡(jiǎn)短的定義就是“從支持?jǐn)?shù)據(jù)處理操作的源生成的元素序列”。下面來(lái)對(duì)這句定義中的每一個(gè)關(guān)鍵詞進(jìn)行解釋
●元素序列——就像集合一樣,流也提供了一個(gè)接口挑宠,可以訪問特定元素類型的一組有序值。因?yàn)榧鲜菙?shù)據(jù)結(jié)構(gòu)颓影,所以它的主要目的是以特定的時(shí)間/空間復(fù)雜度存儲(chǔ)和訪問元素(如ArrayList 與 LinkedList)各淀。但流的目的在于表達(dá)計(jì)算,比如filter诡挂、sorted和map碎浇。集合講的是數(shù)據(jù)临谱,流講的是計(jì)算。
●源——流會(huì)使用一個(gè)提供數(shù)據(jù)的源奴璃,如集合悉默、數(shù)組或輸入/輸出資源。 請(qǐng)注意苟穆,從有序集合生成流時(shí)會(huì)保留原有的順序抄课。由列表生成的流,其元素順序與列表一致雳旅。
●數(shù)據(jù)處理操作——流的數(shù)據(jù)處理功能支持類似于數(shù)據(jù)庫(kù)的操作跟磨,以及函數(shù)式編程語(yǔ)言中的常用操作,如filter攒盈、map抵拘、reduce、find沦童、match仑濒、sort等。流操作可以順序執(zhí)行偷遗,也可并行執(zhí)行墩瞳。
此外,流操作有兩個(gè)重要的特點(diǎn)氏豌。
●流水線——很多流操作本身會(huì)返回一個(gè)流喉酌,這樣多個(gè)操作就可以鏈接起來(lái),形成一個(gè)大的流水線泵喘。流水線的操作可以看作對(duì)數(shù)據(jù)源進(jìn)行數(shù)據(jù)庫(kù)式查詢泪电。
●內(nèi)部迭代——與使用迭代器外部迭代的集合不同,流的迭代操作是在背后進(jìn)行的纪铺。
--摘自《Java 8 In Action》
■總結(jié):整體來(lái)看相速,流式思想類似于車間的“生產(chǎn)流水線”。
圖中展示了過濾鲜锚、映射突诬、跳過、計(jì)數(shù)等多步操作芜繁,每一個(gè)豎著的方框都是一個(gè)“流”旺隙,調(diào)用指定的方法,可以從一個(gè)“流”轉(zhuǎn)換為另一個(gè)“流”骏令。
內(nèi)部迭代和外部迭代
使用iterator迭代器迭代集合的方式蔬捷,稱之為外部迭代,說的通俗一點(diǎn)榔袋,就是需要我們程序猿手動(dòng)的對(duì)這個(gè)集合進(jìn)行種種操作才能得到想要結(jié)果的迭代方式周拐,叫做外部迭代铡俐。
與外部迭代所對(duì)應(yīng)的,則是內(nèi)部迭代妥粟,內(nèi)部迭代與之相反高蜂,是集合本身內(nèi)部通過流進(jìn)行了處理之后,程序猿們只需要直接取結(jié)果就行了罕容,這種迭代稱為內(nèi)部迭代。
圖解:
代碼演示:
@Test
public void test2() throws Exception {
System.out.println("=======================外部迭代=========================");
List<Integer> list = Arrays.asList(1, 2, 1, 3, 3, 2, 4);
for (Integer integer : list) {
System.out.println(integer);
}
Iterator<Integer> iterator = list.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next());
}
System.out.println("=======================內(nèi)部迭代=========================");
Stream<Integer> stream = list.stream().filter(i -> {
System.out.println("內(nèi)部迭代惰性求值");
return i % 2 == 0;
});
stream.forEach(System.out::println);//只有執(zhí)行終止操作的時(shí)候才會(huì)真正執(zhí)行中間操作(惰性求值)
}