摘要:和不同,其沒有接收參數(shù)。用于剔除重復(fù),與數(shù)據(jù)庫中的用法一致??梢詫φ土髑笞畲笾?,返回。這兩個方法是結(jié)束操作,只能調(diào)用一次。
常用的函數(shù)接口記錄方便以后翻吧
接口 | 參數(shù) | 返回類型 | 說明 |
---|---|---|---|
Predicate |
T | boolean | 輸入某個值,輸出boolean 值,用于對某值進(jìn)行判定 |
Consumer |
T | void | 輸入某值,無輸出。用于消費(fèi)某值 |
Function |
T | R | 輸入某類型值,輸出另種類型值,用于類型轉(zhuǎn)化等 |
Supplier |
None | T | 無輸入,輸出某值,用于生產(chǎn)某值 |
UnaryOperator |
T | T | 輸入某類型值,輸出同類型值,用于值的同類型轉(zhuǎn)化,如對值進(jìn)行四則運(yùn)算等 |
BinaryOperator |
(T,T) | T | 輸入兩個某類型值,輸出一個同類型值,用于兩值合并等 |
Predicates是包含一個參數(shù)的布爾值接口。其包括一些缺省方法,組合他們使用可以實現(xiàn)復(fù)雜的業(yè)務(wù)邏輯(如:and, or, negate)。示例代碼如下:
Predicatepredicate = (s) -> s.length() > 0; predicate.test("foo"); // true predicate.negate().test("foo"); // false Predicate nonNull = Objects::nonNull; Predicate isNull = Objects::isNull; Predicate isEmpty = String::isEmpty; Predicate isNotEmpty = isEmpty.negate();
Functions接口接收一個參數(shù)并產(chǎn)生一個結(jié)果。其缺省方法通常被用來鏈接多個功能一起使用 (compose, andThen)。
FunctiontoInteger = Integer::valueOf; Function backToString = toInteger.andThen(String::valueOf); backToString.apply("123"); // "123"
Suppliers接口生成一個給定類型結(jié)果。和Functions不同,其沒有接收參數(shù)。
SupplierpersonSupplier = Person::new; personSupplier.get(); // new Person
Consumers表現(xiàn)執(zhí)行帶有單個輸入?yún)?shù)的操作。
Consumergreeter = (p) -> System.out.println("Hello, " + p.firstName); greeter.accept(new Person("Luke", "Skywalker"));
Comparators是從java舊版本升級并增加了一些缺省方法。
ComparatorStream 常用方法comparator = (p1, p2) -> p1.firstName.compareTo(p2.firstName); Person p1 = new Person("John", "Doe"); Person p2 = new Person("Alice", "Wonderland"); comparator.compare(p1, p2); // > 0 comparator.reversed().compare(p1, p2); // < 0
將現(xiàn)有數(shù)據(jù)結(jié)構(gòu)轉(zhuǎn)化成Stream
Streams = Stream.of(1, 2, 3, 4, 5); Stream s = Arrays.stream(arr); Stream s = aList.stream();
通過Stream.generate()方法:
// 這種方法通常表示無限序列 Streams = Stream.generate(SuppLier s); // 創(chuàng)建全體自然數(shù)的Stream class NatualSupplier implements Supplier { BigInteger next = BigInteger.ZERO; @Override public BigInteger get() { next = next.add(BigInteger.ONE); return next; } }
通過其他方法返回
Streamlines = Files.lines(Path.get(filename)) ...
把一種操作運(yùn)算映射到Stream的每一個元素上,從而完成一個Stream到另一個Stream的轉(zhuǎn)換
map方法接受的對象是Function接口,這個接口是一個函數(shù)式接口:
Stream map(Function super T, ? extends R> mapper); @FunctionalInterface public interface Function { // 將T轉(zhuǎn)換為R R apply(T t); }
使用:
// 獲取Stream里每個數(shù)的平方的集合 Streamns = Stream.of(1, 2, 3, 4, 5); ns.map(n -> n * n).forEach(System.out::println);
map方法是一個一對一的映射,每輸入一個數(shù)據(jù)也只會輸出一個值。
flatMap方法是一對多的映射,對每一個元素映射出來的仍舊是一個Stream,然后會將這個子Stream的元素映射到父集合中:
Stream> inputStream = Stream.of(Arrays.asList(1), Arrays.asList(2, 3), Arrays.asList(4, 5, 6)); List
integerList = inputStream.flatMap((childList) -> childList.stream()).collect(Collectors.toList()); //將一個“二維數(shù)組”flat為“一維數(shù)組” integerList.forEach(System.out::println);
filter方法用于過濾Stream中的元素,并用符合條件的元素生成一個新的Stream。
filter方法接受的參數(shù)是Predicate接口對象,這個接口是一個函數(shù)式接口:
Streamfilter(Predicate super T>) predicate; @FunctionInterface public interface Predicate { // 判斷元素是否符合條件 boolean test(T t); }
使用
// 獲取當(dāng)前Stream所有偶數(shù)的序列 Streamns = Stream.of(1, 2, 3, 4, 5); ns.filter(n -> n % 2 == 0).forEach(System.out::println);
limit用于限制獲取多少個結(jié)果,與數(shù)據(jù)庫中的limit作用類似,skip用于排除前多少個結(jié)果。
sorted函數(shù)需要傳入一個實現(xiàn)Comparator函數(shù)式接口的對象,該接口的抽象方法compare接收兩個參數(shù)并返回一個整型值,作用就是排序,與其他常見排序方法一致。
distinct用于剔除重復(fù),與數(shù)據(jù)庫中的distinct用法一致。
findFirst方法總是返回第一個元素,如果沒有則返回空,它的返回值類型是Optional
Streamstream = users.stream(); Optional userID = stream.filter(User::isVip).sorted((t1, t2) -> t2.getBalance() - t1.getBalance()).limit(3).map(User::getUserID).findFirst(); userID.ifPresent(uid -> System.out.println("Exists"));
min可以對整型流求最小值,返回OptionalInt。
max可以對整型流求最大值,返回OptionalInt。
這兩個方法是結(jié)束操作,只能調(diào)用一次。
allMatch:Stream中全部元素符合傳入的predicate返回 true
anyMatch:Stream中只要有一個元素符合傳入的predicate返回 true
noneMatch:Stream中沒有一個元素符合傳入的predicate返回 true
reduce方法將一個Stream的每一個元素一次作用于BiFunction,并將結(jié)果合并。
reduce方法接受的方法是BinaryOperator接口對象。
Optionalreduce(BinaryOperator accumulator); @FuncationalInterface public interface BinaryOperator extends BiFunction { // Bi操作,兩個輸入,一個輸出 T apply(T t, T u); }
使用:
// 求當(dāng)前Stream累乘的結(jié)果 Streamns = Stream.of(1, 2, 3, 4, 5); int r = ns.reduce( (x, y) -> x * y ).get(); System.out.println(r);
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/73566.html
摘要:函數(shù)式接口進(jìn)階與默認(rèn)方法詳解上一篇我們快速的借助示例演示了的簡單應(yīng)用,體會到了使用對集合處理的便捷和其與函數(shù)式接口密不可分的關(guān)系,所以為了更高效的使用,有必要更熟練的掌握函數(shù)式接口。 Java8-5-函數(shù)式接口進(jìn)階與默認(rèn)方法詳解上一篇我們快速的借助示例演示了stream api的簡單應(yīng)用,體會到了使用stream api對集合處理的便捷和其與函數(shù)式接口密不可分的關(guān)系,所以為了更高效的使...
摘要:所以通過上面的例子可以看出函數(shù)式編程和結(jié)合的非常緊密。小結(jié)本篇簡單介紹了函數(shù)式編程與應(yīng)用及類方法引用的使用,表達(dá)式讓老版本的代碼更簡潔,方法引用讓表達(dá)式更簡潔,實際上就是表達(dá)式的一種語法糖。 上一篇文章中,我們介紹了幾個Java8內(nèi)置的函數(shù)式接口的特點(diǎn)和使用方式,并在最后引出了stream api的知識點(diǎn),接下來我們開始學(xué)習(xí)Java8中的stream api。先假設(shè)一個簡單的需求,存在...
摘要:接下來看下如果使用提供的接口會有哪些改進(jìn)首先看下接口定義省略該函數(shù)式接口唯一的抽象方法接收一個參數(shù),有返回值。是不是有點(diǎn)體驗到函數(shù)式編程的靈活之處。 上一篇文章中,我們總體介紹了創(chuàng)建函數(shù)式接口實例的幾種方式以及Java8中接口新增的默認(rèn)方法特性,接下來我們來看下Java8中已經(jīng)為我們提供的幾種典型的函數(shù)式接口先看一個示例 public class FunctionTest { ...
摘要:的主要新特性表達(dá)式允許把函數(shù)作為一個方法的參數(shù)傳遞進(jìn)方法中。作用解決被詬病的匿名內(nèi)部類的問題。新特性模塊系統(tǒng)模塊是一個包的容器,最大的變化之一是引入模塊系統(tǒng)。支持標(biāo)準(zhǔn)標(biāo)準(zhǔn)是協(xié)議的最新版本,新的支持和流以及服務(wù)器推送特性。 Java 8 的主要新特性 1. Lambda 表達(dá)式 Lambda 允許把函數(shù)作為一個方法的參數(shù)傳遞進(jìn)方法中。 作用:解決 Java 被詬病的匿名內(nèi)部類的問題。 2...
摘要:數(shù)據(jù)流教程原文譯者飛龍協(xié)議這個示例驅(qū)動的教程是數(shù)據(jù)流的深入總結(jié)。但是的數(shù)據(jù)流是完全不同的東西。數(shù)據(jù)流是單體,并且在函數(shù)式編程中起到重要作用。列表上的所有流式操作請見數(shù)據(jù)流的?;镜臄?shù)據(jù)流使用特殊的表達(dá)式,例如,而不是,而不是。 Java 8 數(shù)據(jù)流教程 原文:Java 8 Stream Tutorial 譯者:飛龍 協(xié)議:CC BY-NC-SA 4.0 這個示例驅(qū)動的教程是J...
閱讀 1648·2021-10-18 13:35
閱讀 2423·2021-10-09 09:44
閱讀 882·2021-10-08 10:05
閱讀 2839·2021-09-26 09:47
閱讀 3677·2021-09-22 15:22
閱讀 493·2019-08-29 12:24
閱讀 2071·2019-08-29 11:06
閱讀 2909·2019-08-26 12:23