一文詳解Java8中的方法引用與構(gòu)造器引用
前言
本節(jié)我總結(jié)結(jié)合Lambda表達(dá)式使用的方法引用,本質(zhì)上還是Lambda表達(dá)式!
什么是方法引用
當(dāng)要傳遞給 Lambda 體的操作,已經(jīng)有實(shí)現(xiàn)的方法了,可以使用方法引用!
方法引用可以看做是 Lambda 表達(dá)式深層次的表達(dá)。換句話說,方法引用就是 Lambda 表達(dá)式,也就是函數(shù)式接口的一個實(shí)例,通過方法的名字來指向一個方法,可以認(rèn)為是 Lambda 表達(dá)式的一個語法糖。
要求:實(shí)現(xiàn)接口的抽象方法的參數(shù)列表和返回值類型,必須與方法引用的方法的參數(shù)列表和返回值類型保持一致!
格式:使用操作符"::"將類(或?qū)ο螅┡c方法名分隔開來。
有如下三種主要使用情況:
- >對象::實(shí)例方法名
- >類::靜態(tài)方法名
- >類::實(shí)例方法名
方法引用的三種情況案例
情況一:對象::實(shí)例方法名
public static void main(String[] args) {
// 情況一:對象::實(shí)例方法名
// Consumer 中的 void accept(T t)
// void accept(T t) 與 打印流中的void println(T t) 參數(shù)類型和返回值一致,因此可以用方法引用
// Lambda 表達(dá)式
Consumer<String> con1 = str -> System.out.println(str);
con1.accept("aniu1");
// 方法引用改寫
PrintStream ps = System.out; //對象::實(shí)例方法名
Consumer<String> con2 = ps::println;
con2.accept("aniu2");
}

情況二:類::靜態(tài)方法名
// 情況二:類::靜態(tài)方法 // Comparator 中的 int compare(T t1,T t2) // int compare(T t1,T t2) 與 Integer中的int compare(T t1,T t2) 參數(shù)類型和返回值一致,因此可以用方法引用 // Lambda 表達(dá)式 Comparator<Integer> com3 = (t1,t2) -> Integer.compare(t1,t2); System.out.println(com3.compare(12, 21)); // 方法引用改寫 Comparator<Integer> com4 = Integer::compare; System.out.println(com4.compare(12, 21));
情況三:類::實(shí)例方法名
// 情況三:類::實(shí)例方法名 (有難度)---前面方法引用的要求針對的是情況一和情況二,對情況三不適用
// Comparator 中的 int compare(T t1,T t2)
// String 中的 int t1.compareTo(t2) // T t1 作為compareTo的調(diào)用者,T的類型作為 類::實(shí)例方法名 中的類
// Lambda 表達(dá)式
Comparator<String> com5 = (s1,s2) -> s1.compareTo(s2);
System.out.println(com5.compare("A", "B"));
// 方法引用改寫
Comparator<String> com6 = String::compareTo;
System.out.println(com6.compare("A", "B"));
這一塊還是比較抽象的,多去理解,我不在多舉例子!
構(gòu)造器引用
和方法引用類似,函數(shù)式接口的抽象方法的形參列表和構(gòu)造器的形參列表一致,抽象方法的返回值類型即為構(gòu)造器所屬的類的類型!
package 構(gòu)造器引用;
import java.util.function.Supplier;
/**
* @Author:Aniu
* @Date:2023/2/23 21:33
* @description TODO
*/
public class Demo {
public static void main(String[] args) {
// 原始寫法
Supplier<People> sup1 = new Supplier<People>() {
@Override
public People get() {
return new People();
}
};
sup1.get();
// Lambda 表達(dá)式
Supplier<People> sup2 = () -> new People();
sup2.get();
// 構(gòu)造器引用
// Supplier中的T get()
// People 的空參構(gòu)造器 People()
Supplier<People> sup3 = People::new;
sup3.get();
}
}
class People{
String name;
int age;
public People(){
System.out.println("空參構(gòu)造器被調(diào)用啦!");
}
public People(int a){
this.age = a;
System.out.println("有參構(gòu)造器被調(diào)用啦!");
}
}

// Lambda 表達(dá)式 Function<Integer,People> fun1 = id -> new People(id); fun1.apply(18); // 構(gòu)造器引用 // Function 中的R apply(T t) // 函數(shù)式接口 // People 的有參構(gòu)造器 People(T t) Function<Integer,People> fun4 = People::new; fun1.apply(18);

還有數(shù)組引用,這里不再總結(jié),感興趣的可以去了解!
到此這篇關(guān)于一文詳解Java8中的方法引用與構(gòu)造器引用的文章就介紹到這了,更多相關(guān)Java8方法引用 構(gòu)造器引用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java設(shè)計模式之裝飾器模式(Decorator)
這篇文章主要為大家詳細(xì)介紹了java設(shè)計模式之裝飾器模式Decorator,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01
學(xué)習(xí)Java之自定義異常與NullPointerException的處理
有時候Java自身提供的異常類并不能很好地表達(dá)我們的需求,所以這時候我們就可以自定義異常,也就是說,我們可以制造出一個自己的異常類,這樣就可以拋出或捕獲自己的異常了,本文就給大家詳細(xì)講講Java自定義異常與NullPointerException的處理2023-08-08
Spring Boot @Async 異步任務(wù)執(zhí)行方法
本篇文章主要介紹了Spring Boot @Async 異步任務(wù)執(zhí)行方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05
Executor攔截器高級教程QueryInterceptor的規(guī)范
今天小編就為大家分享一篇關(guān)于Executor攔截器高級教程QueryInterceptor的規(guī)范,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12
reactor-logback的AsyncAppender執(zhí)行流程源碼解讀
這篇文章主要為大家介紹了reactor-logback的AsyncAppender執(zhí)行流程源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12
使用BigDecimal去掉小數(shù)點(diǎn)后無用的0
這篇文章主要介紹了使用BigDecimal去掉小數(shù)點(diǎn)后無用的0操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08

