Java中stream是什么及如何使用
Java中stream是什么?有什么作用?如何使用?
在Java中,Stream(流)是一種用于操作集合(Collection)、數(shù)組等數(shù)據(jù)源的API。它提供了一種功能強大且表達(dá)力高的編程模型,可以用更簡潔、更具可讀性的方式處理數(shù)據(jù)。
Stream的主要作用是進行數(shù)據(jù)的轉(zhuǎn)換、篩選、聚合等操作,可以極大地簡化對數(shù)據(jù)的處理。使用Stream可以避免顯式地使用迭代器或循環(huán)來操作集合,提高代碼的可讀性和簡潔性。
以下是使用Stream的一般步驟:
- 獲取一個數(shù)據(jù)源(如List、Set、數(shù)組等)。
- 調(diào)用
stream()
方法獲取數(shù)據(jù)流。 - 使用各種中間操作對數(shù)據(jù)流進行處理(如篩選、轉(zhuǎn)換等)。
- 調(diào)用終端操作執(zhí)行對數(shù)據(jù)流的最終處理(如聚合、收集結(jié)果等)。
下面通過示例代碼詳細(xì)介紹Stream的使用:
import java.util.Arrays; import java.util.List; import java.util.stream.Collectors; public class StreamExample { public static void main(String[] args) { // 1. 獲取數(shù)據(jù)源 List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10); // 2. 獲取數(shù)據(jù)流 List<Integer> evenSquares = numbers.stream() // 3. 中間操作:篩選偶數(shù)并計算平方 .filter(n -> n % 2 == 0) .map(n -> n * n) // 4. 終端操作:收集結(jié)果 .collect(Collectors.toList()); System.out.println(evenSquares); // 輸出:[4, 16, 36, 64, 100] } }
在上述示例中,我們首先獲取了一個整數(shù)列表作為數(shù)據(jù)源。然后,通過調(diào)用stream()
方法獲取了一個數(shù)據(jù)流。接著,使用中間操作filter()
篩選出偶數(shù),再使用map()
計算平方。最后,通過終端操作collect()
將結(jié)果收集到列表中。
這只是Stream的基本用法,Stream還提供了豐富的中間操作和終端操作供使用,如sorted()
、distinct()
、reduce()
等。通過組合不同的操作,可以實現(xiàn)復(fù)雜的數(shù)據(jù)處理邏輯。
stream用法:
filter(Predicate<T> predicate)
:根據(jù)指定的條件篩選元素。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); List<Integer> result = list.stream().filter(n -> n % 2 == 0).collect(Collectors.toList()); // 輸出:[2, 4]
map(Function<T, R> mapper)
:將元素轉(zhuǎn)換為另一種類型。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); List<String> result = list.stream().map(n -> "Number: " + n).collect(Collectors.toList()); // 輸出:["Number: 1", "Number: 2", "Number: 3", "Number: 4", "Number: 5"]
flatMap(Function<T, Stream<R>> mapper)
:將流中的每個元素轉(zhuǎn)換為一個流,然后將所有流合并為一個流。
List<List<Integer>> lists = Arrays.asList(Arrays.asList(1, 2), Arrays.asList(3, 4, 5)); List<Integer> result = lists.stream().flatMap(list -> list.stream()).collect(Collectors.toList()); // 輸出:[1, 2, 3, 4, 5]
distinct()
:去除流中重復(fù)的元素。
List<Integer> list = Arrays.asList(1, 2, 3, 2, 4, 1, 5); List<Integer> result = list.stream().distinct().collect(Collectors.toList()); // 輸出:[1, 2, 3, 4, 5]
sorted()
:對流中元素進行排序。
List<Integer> list = Arrays.asList(5, 3, 1, 2, 4); List<Integer> result = list.stream().sorted().collect(Collectors.toList()); // 輸出:[1, 2, 3, 4, 5]
peek(Consumer<T> action)
:對流中的元素執(zhí)行指定的操作。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); List<Integer> result = list.stream().peek(n -> System.out.println("Processing element: " + n)).collect(Collectors.toList()); // 輸出:Processing element: 1 Processing element: 2 Processing element: 3 Processing element: 4 Processing element: 5
limit(long maxSize)
:截取流中的前N個元素。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); List<Integer> result = list.stream().limit(3).collect(Collectors.toList()); // 輸出:[1, 2, 3]
skip(long n)
:跳過流中的前N個元素。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); List<Integer> result = list.stream().skip(3).collect(Collectors.toList()); // 輸出:[4, 5]
1.forEach(Consumer<T> action)
:對流中的每個元素執(zhí)行指定的操作。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); list.stream().forEach(n -> System.out.println(n)); // 輸出:1 2 3 4 5
2.collect(Collector<T, A, R> collector)
:將流中的元素收集到一個容器中。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); List<Integer> result = list.stream().filter(n -> n % 2 == 0).collect(Collectors.toList()); // 輸出:[2, 4]
3.count()
:返回流中的元素個數(shù)。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); long count = list.stream().count(); // 輸出:5
4.reduce(T identity, BinaryOperator<T> accumulator)
:將流中的元素逐個與初始值進行操作,返回最終結(jié)果。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); int sum = list.stream().reduce(0, (a, b) -> a + b); // 輸出:15
5.findFirst()
和findAny()
:返回流中的第一個元素或任意一個元素。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); Optional<Integer> first = list.stream().findFirst(); Optional<Integer> any = list.stream().findAny(); // 輸出:1
6.max()
和min()
:返回流中的最大元素或最小元素。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); Optional<Integer> max = list.stream().max(Integer::compareTo); Optional<Integer> min = list.stream().min(Integer::compareTo); // 輸出:5 1
7.allMatch(Predicate<T> predicate)
、anyMatch(Predicate<T> predicate)
和noneMatch(Predicate<T> predicate)
:分別返回流中所有元素是否滿足指定條件、是否至少有一個元素滿足指定條件、是否沒有元素滿足指定條件。
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); boolean allMatch = list.stream().allMatch(n -> n > 0); boolean anyMatch = list.stream().anyMatch(n -> n % 2 == 0); boolean noneMatch = list.stream().noneMatch(n -> n > 5); // 輸出:true true false
Stream是Java 8引入的一組 API,它提供了一種新的并行處理集合數(shù)據(jù)的方式,可以讓開發(fā)者更加方便、高效地對集合進行操作。
Stream 是基于管道(Pipe)和過濾器(Filter)的模式,通過對數(shù)據(jù)源執(zhí)行一系列中間操作(Intermediate Operations)和終端操作(Terminal Operations)來完成對數(shù)據(jù)的處理。
利用 Stream API,我們可以在不改變原有數(shù)據(jù)結(jié)構(gòu)的前提下,方便地進行數(shù)據(jù)的篩選、排序、映射、聚合等操作,并且這些操作可以串行或并行地執(zhí)行,以提高計算效率。
Stream流用途:
簡化集合操作:Stream提供了豐富的中間操作和終端操作,可以更簡潔地對集合進行篩選、轉(zhuǎn)換、排序等操作,避免了使用傳統(tǒng)的for循環(huán)等繁瑣的操作。
并行處理:Stream API天然支持并行處理,可以自動將集合數(shù)據(jù)分成多個部分并行處理,提高處理的效率。
減少內(nèi)存消耗:Stream API采用惰性求值的方式,在處理大量數(shù)據(jù)時可以只在需要時才進行計算,避免了一次性加載所有數(shù)據(jù)到內(nèi)存中。
代碼簡潔、可讀性好:Stream的鏈?zhǔn)秸{(diào)用和函數(shù)式編程風(fēng)格使代碼更加簡潔、易讀。每個操作都可以看作是對數(shù)據(jù)流的一次轉(zhuǎn)換或處理,使得代碼更加直觀。
支持無限大的數(shù)據(jù)集:Stream API對于無限大的數(shù)據(jù)集也能處理,并且可以利用短路特性進行優(yōu)化。
與Lambda表達(dá)式結(jié)合:Stream API廣泛使用Lambda表達(dá)式,可以簡化代碼,提高開發(fā)效率。
到此這篇關(guān)于Java中stream是什么?有什么作用?如何使用?的文章就介紹到這了,更多相關(guān)Java中stream用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Idea導(dǎo)入多個maven項目到同一目錄下的方法示例
這篇文章主要介紹了Idea導(dǎo)入多個maven項目到同一目錄下,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07Java服務(wù)端架構(gòu)之微服務(wù)與單體服務(wù)的權(quán)衡方式
本文比較了Java微服務(wù)與單體服務(wù)的優(yōu)缺點,并提供了相應(yīng)的示例代碼,微服務(wù)架構(gòu)具有可擴展性、技術(shù)多樣性等優(yōu)勢,但復(fù)雜性和網(wǎng)絡(luò)延遲是缺點,單體服務(wù)架構(gòu)簡單易部署,但擴展性差,選擇哪種架構(gòu)應(yīng)根據(jù)項目需求和團隊能力2025-03-03SpringCloud Netflix Ribbon源碼解析(推薦)
這篇文章主要介紹了SpringCloud Netflix Ribbon源碼解析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03解決java.lang.NoClassDefFoundError:lombok/Data報錯問題
在Java開發(fā)中,使用Lombok庫簡化代碼非常普遍,今天在啟動拉取的git代碼時,遇到了java.lang.NoClassDefFoundError:lombok/Data的報錯,經(jīng)過檢查,發(fā)現(xiàn)錯誤的原因是將Date誤寫為Data,且錯誤地引用了lombok.Data包2024-09-09Mybatis-plus使用selectList查詢數(shù)據(jù)為null的問題及解決辦法
這篇文章主要介紹了Mybatis-plus使用selectList查詢數(shù)據(jù)為null的問題及解決方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07Java使用FastExcel導(dǎo)入支持多種時間格式
FastExcel 是一個采用純 java 開發(fā)的 excel 文件讀寫組件,支持 Excel'97(-2003)(BIFF8)文件格式,本文主要介紹了如何使用FastExcel導(dǎo)入支持多種時間格式,感興趣的可以了解2024-12-12