溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java中Stream流怎么實(shí)現(xiàn)合并操作

發(fā)布時(shí)間:2020-07-23 10:48:06 來(lái)源:億速云 閱讀:250 作者:小豬 欄目:編程語(yǔ)言

小編這次要給大家分享的是Java中Stream流怎么實(shí)現(xiàn)合并操作,文章內(nèi)容豐富,感興趣的小伙伴可以來(lái)了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

1. 前言

Java Stream Api 提供了很多有用的 Api 讓我們很方便將集合或者多個(gè)同類型的元素轉(zhuǎn)換為流進(jìn)行操作。今天我們來(lái)看看如何合并 Stream 流。

2. Stream 流的合并

Stream 流合并的前提是元素的類型能夠一致。

2.1 concat

最簡(jiǎn)單合并流的方法是通過(guò) Stream.concat() 靜態(tài)方法:

Stream<Integer> stream = Stream.of(1, 2, 3);
Stream<Integer> another = Stream.of(4, 5, 6);
Stream<Integer> concat = Stream.concat(stream, another);

List<Integer> collect = concat.collect(Collectors.toList());
List<Integer> expected = Lists.list(1, 2, 3, 4, 5, 6);

Assertions.assertIterableEquals(expected, collect);

這種合并是將兩個(gè)流一前一后進(jìn)行拼接:

Java中Stream流怎么實(shí)現(xiàn)合并操作

2.2 多個(gè)流的合并

多個(gè)流的合并我們也可以使用上面的方式進(jìn)行“套娃操作”:

Stream.concat(Stream.concat(stream, another), more);

你可以一層一層繼續(xù)套下去,如果需要合并的流多了,看上去不是很清晰。

我之前介紹過(guò)一個(gè)Stream 的 flatmap 操作 ,它的大致流程可以參考里面的這一張圖:

Java中Stream流怎么實(shí)現(xiàn)合并操作

因此我們可以通過(guò) flatmap 進(jìn)行實(shí)現(xiàn)合并多個(gè)流:

Stream<Integer> stream = Stream.of(1, 2, 3);
Stream<Integer> another = Stream.of(4, 5, 6);
Stream<Integer> third = Stream.of(7, 8, 9);
Stream<Integer> more = Stream.of(0);
Stream<Integer> concat = Stream.of(stream,another,third,more).
  flatMap(integerStream -> integerStream);
List<Integer> collect = concat.collect(Collectors.toList());
List<Integer> expected = Lists.list(1, 2, 3, 4, 5, 6, 7, 8, 9, 0);
Assertions.assertIterableEquals(expected, collect);

這種方式是先將多個(gè)流作為元素生成一個(gè)類型為 Stream<Stream<T>> 的流,然后進(jìn)行 flatmap 平鋪操作合并。

2.3 第三方庫(kù)

有很多第三方的強(qiáng)化庫(kù) StreamEx 、Jooλ 都可以進(jìn)行合并操作。另外反應(yīng)式編程庫(kù) Reactor 3 也可以將 Stream 流合并為反應(yīng)流,在某些場(chǎng)景下可能會(huì)有用。這里演示一下:

List<Integer> block = Flux.fromStream(stream)
            .mergeWith(Flux.fromStream(another))
                 .collectList()
                 .block();

看完這篇關(guān)于Java中Stream流怎么實(shí)現(xiàn)合并操作的文章,如果覺(jué)得文章內(nèi)容寫(xiě)得不錯(cuò)的話,可以把它分享出去給更多人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI