一文詳解Java8中的方法引用與構造器引用
前言
本節(jié)我總結結合Lambda表達式使用的方法引用,本質(zhì)上還是Lambda表達式!
什么是方法引用
當要傳遞給 Lambda 體的操作,已經(jīng)有實現(xiàn)的方法了,可以使用方法引用!
方法引用可以看做是 Lambda 表達式深層次的表達。換句話說,方法引用就是 Lambda 表達式,也就是函數(shù)式接口的一個實例,通過方法的名字來指向一個方法,可以認為是 Lambda 表達式的一個語法糖。
要求:實現(xiàn)接口的抽象方法的參數(shù)列表和返回值類型,必須與方法引用的方法的參數(shù)列表和返回值類型保持一致!
格式:使用操作符"::"將類(或對象)與方法名分隔開來。
有如下三種主要使用情況:
- >對象::實例方法名
- >類::靜態(tài)方法名
- >類::實例方法名
方法引用的三種情況案例
情況一:對象::實例方法名
public static void main(String[] args) { // 情況一:對象::實例方法名 // Consumer 中的 void accept(T t) // void accept(T t) 與 打印流中的void println(T t) 參數(shù)類型和返回值一致,因此可以用方法引用 // Lambda 表達式 Consumer<String> con1 = str -> System.out.println(str); con1.accept("aniu1"); // 方法引用改寫 PrintStream ps = System.out; //對象::實例方法名 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 表達式 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));
情況三:類::實例方法名
// 情況三:類::實例方法名 (有難度)---前面方法引用的要求針對的是情況一和情況二,對情況三不適用 // Comparator 中的 int compare(T t1,T t2) // String 中的 int t1.compareTo(t2) // T t1 作為compareTo的調(diào)用者,T的類型作為 類::實例方法名 中的類 // Lambda 表達式 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"));
這一塊還是比較抽象的,多去理解,我不在多舉例子!
構造器引用
和方法引用類似,函數(shù)式接口的抽象方法的形參列表和構造器的形參列表一致,抽象方法的返回值類型即為構造器所屬的類的類型!
package 構造器引用; 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 表達式 Supplier<People> sup2 = () -> new People(); sup2.get(); // 構造器引用 // Supplier中的T get() // People 的空參構造器 People() Supplier<People> sup3 = People::new; sup3.get(); } } class People{ String name; int age; public People(){ System.out.println("空參構造器被調(diào)用啦!"); } public People(int a){ this.age = a; System.out.println("有參構造器被調(diào)用啦!"); } }
// Lambda 表達式 Function<Integer,People> fun1 = id -> new People(id); fun1.apply(18); // 構造器引用 // Function 中的R apply(T t) // 函數(shù)式接口 // People 的有參構造器 People(T t) Function<Integer,People> fun4 = People::new; fun1.apply(18);
還有數(shù)組引用,這里不再總結,感興趣的可以去了解!
到此這篇關于一文詳解Java8中的方法引用與構造器引用的文章就介紹到這了,更多相關Java8方法引用 構造器引用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
學習Java之自定義異常與NullPointerException的處理
有時候Java自身提供的異常類并不能很好地表達我們的需求,所以這時候我們就可以自定義異常,也就是說,我們可以制造出一個自己的異常類,這樣就可以拋出或捕獲自己的異常了,本文就給大家詳細講講Java自定義異常與NullPointerException的處理2023-08-08Spring Boot @Async 異步任務執(zhí)行方法
本篇文章主要介紹了Spring Boot @Async 異步任務執(zhí)行方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05Executor攔截器高級教程QueryInterceptor的規(guī)范
今天小編就為大家分享一篇關于Executor攔截器高級教程QueryInterceptor的規(guī)范,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12reactor-logback的AsyncAppender執(zhí)行流程源碼解讀
這篇文章主要為大家介紹了reactor-logback的AsyncAppender執(zhí)行流程源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-12-12