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!

推薦閱讀: