JAVALambda表達式與函數式接口詳解
Lambda表達式的誕生是為瞭解決JAVA創建匿名內部類代碼冗餘的問題。例子如下:
public class Lambda { public static void main(String[] args) { Gog gog = new Gog() { @Override public void say() { System.out.println("WOW"); } }; gog.say(); } } interface Gog { void say(); }
這裡我們想實現接口的say方法,由於實例化接口會創建匿名內部類,需要將接口中的所有方法實現。為瞭實現一個簡單的方法冗餘瞭許多代碼出來。那麼如果用Lambda 表達式去簡化呢。例子如下:
public class Lambda { public static void main(String[] args) { //Lambda表達式的寫法即: ()-> {函數實現} 當函數實現隻有一行代碼時,可以省略大括號 如下所示: Gog gog = () -> System.out.println("WOW"); gog.say(); } } interface Gog { void say(); }
隻包含一個抽象方法的接口稱為函數式接口。而也隻有函數式接口可以利用Lambda 表達式進行簡化。其實原因很簡單。如果接口中有多個方法,Lambda表達式將無法明確調用的是那個函數。
而根據抽象函數的返回值與參數列表,函數式接口可以簡單的分為以下4種類型:
//1.供給型接口:Interface Supplier<T>沒有參數,有返回值 interface Supplier { String say(); } //2.消費型接口:Interface Consumer<T>隻有輸入,沒有返回值 interface Consumer{ void say(String name); } //3.斷定型接口:Interface Predicate<T>傳入參數t,返回值類型為boolean類型 interface Predicate{ boolean say(String name); } //4.函數型接口:Interface Function<T,R>傳入參數類型為T,返回值類型為R interface Function{ String say(int age); }
舉幾個我們身邊中常用到的Lambda函數
public class MyThread { public static void main(String[] args) { new Thread(() -> { System.out.println("創建線程"); }).start(); } }
如上代碼大傢必然很熟悉,一個很簡單的創建線程的方法。我們進入Thread對應的構造函數看看。
可以看到,我們調用的構造函數的入參是Runnable接口,而我們在看看我們創建的時候,明明使用的是Lambda 表達式,那麼可以斷定,Runnable接口必定是一個函數式接口
註意!!由於jdk8之後,接口中的函數可以擁有默認實現,這種擁有默認實現的方法,並不會影響這個接口成為函數式接口。例子如下:
public class Lambda { public static void main(String[] args) { Supplier supplier = ()-> "wow"; System.out.println(supplier.say()); } } interface Supplier { String say(); default String name(){ return ""; } }
Supplier 接口中有兩個函數,但是依然可以成為函數式接口,利用Lambda 表達式進行簡化。
到此這篇關於JAVALambda表達式與函數式接口詳解的文章就介紹到這瞭,更多相關JAVALambda表達式與函數式接口內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!