Lambda表达式的基础知识
語(yǔ)法
Java lambda表達(dá)式包含參數(shù)列表與函數(shù)體2部分,語(yǔ)法為:
args -> expr
例如:
p -> p.transfer()
() -> { print "" ;}
(int a ,int b ) -> {}
lambda與匿名內(nèi)部類(lèi)區(qū)別
匿名內(nèi)部類(lèi)可以為任意接口,抽象類(lèi)甚至普通類(lèi)創(chuàng)建實(shí)例——不管有多少個(gè)抽象方法,只要匿名內(nèi)部類(lèi)實(shí)現(xiàn)了所有方法即可。
但是Lambda表達(dá)式只能為函數(shù)式接口創(chuàng)建實(shí)例。
函數(shù)式接口
Java8開(kāi)始支持Lambda表達(dá)式,一個(gè)lambda表達(dá)式都對(duì)應(yīng)一個(gè)類(lèi)型,通常是接口類(lèi)型。而“函數(shù)式接口”是指僅僅只包含一個(gè)抽象方法的接口,每一個(gè)該類(lèi)型的lambda表達(dá)式都會(huì)被匹配到這個(gè)抽象方法。因?yàn)?默認(rèn)方法 不算抽象方法,所以你也可以給你的函數(shù)式接口添加默認(rèn)方法。
??? @FunctionalInterface
??? interface Converter<F, T> {
??????? T convert(F from);
??? }
??? Converter<String, Integer> converter = (from) -> Integer.valueOf(from);
??? Integer converted = converter.convert("123");
??? System.out.println(converted);??? // 123
方法引用
方法引用的標(biāo)準(zhǔn)形式是:類(lèi)名::方法名。(注意:只需要寫(xiě)方法名,不需要寫(xiě)括號(hào))
有以下四種形式的方法引用:
| 類(lèi)型 | 語(yǔ)法 | 對(duì)應(yīng)lambda表達(dá)式 |
| 靜態(tài)方法引用 | ClassType::staticMethodName | (args) -> ClassType.staticMethodName(args) |
| 實(shí)例方法引用 | objRef::instanceMethodName | (args) -> objRef.instanceMethodName(args) |
| 類(lèi)型的實(shí)例方法引用 | ClassType::methodName | (arg1,args2) -> arg1.instanceMethodName(args2) |
| 構(gòu)造器引用 | ClassType::new | (args) -> new ClassType(args) |
| 數(shù)組構(gòu)造器引用 | ClassType[]::new | () -> new ClassType[] |
| 超類(lèi)上的實(shí)例引用 | super::methodName | (args) -> super.instanceMethodName(args) //此lambda表達(dá)式調(diào)用處所在的方式隸屬于類(lèi)的super,通過(guò)this::methodName 引用本類(lèi)的方法。 |
?
?
?
?
?
?
?
?
?
新語(yǔ)法:&
public static <K extends Comparable<? super K>, V> Comparator<Map.Entry<K,V>> comparingByKey() {return (Comparator<Map.Entry<K, V>> & Serializable)(c1, c2) -> c1.getKey().compareTo(c2.getKey());}表示同時(shí)滿足兩個(gè)類(lèi)(接口)。相當(dāng)于:
return (Comparator<Map.Entry<K, V>>) (Serializable)(c1, c2) -> c1.getKey().compareTo(c2.getKey());equals方法在Object中已經(jīng)實(shí)現(xiàn)了。之所以在Comparator中“多此一舉”列出來(lái),主要是為了提醒而不是強(qiáng)制,因?yàn)镺bject中的默認(rèn)實(shí)現(xiàn)可能是不合適的,很多時(shí)候需要修改。?
Optional
這是一個(gè)可以為null的容器對(duì)象。如果值存在則isPresent()方法會(huì)返回true,調(diào)用get()方法會(huì)返回該對(duì)象。
public final class Optional<T> {private static final Optional<?> EMPTY = new Optional<>();private final T value;private Optional() {this.value = null;}public static<T> Optional<T> empty() {@SuppressWarnings("unchecked")Optional<T> t = (Optional<T>) EMPTY;return t;}private Optional(T value) {this.value = Objects.requireNonNull(value);}public static <T> Optional<T> of(T value) {return new Optional<>(value);}public static <T> Optional<T> ofNullable(T value) {return value == null ? empty() : of(value);}public T get() {if (value == null) {throw new NoSuchElementException("No value present");}return value;}public boolean isPresent() {return value != null;}public void ifPresent(Consumer<? super T> consumer) {if (value != null)consumer.accept(value);}... }?
總結(jié)
以上是生活随笔為你收集整理的Lambda表达式的基础知识的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 深入理解Kafka(4)-主题与分区
- 下一篇: java.util.function包