黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 JDK8的新特性詳解

JDK8的新特性詳解

更新時間:2021-06-28 16:35:31 來源:動力節點 瀏覽1284次

JDK8已經發布快4年的時間了,現在來談它的新特性顯得略微的有點“不合時宜”。盡管JDK8已不再“新”,但它的重要特性之一——Lambda表達式依然是不被大部分開發者所熟練運用,甚至不被開發者所熟知。

國內的開發環境大家都知道,有各種的老項目,有各種各樣的發布風險,讓公司以及項目組對新的技術往往望而卻步,有公司甚至時至今日還在使用JDK6來進行項目開發,這導致了在很多技術的選擇上受到了很大限制,進而不能跟隨時代的腳步使得項目甚至公司一步一步走向衰落。

本文簡單認識JDK8的重要新特性之一——Lambda表達式。在JDK8之前,Java是不支持函數式編程的,所謂的函數編程,即可理解是將一個函數(也稱為“行為”)作為一個參數進行傳遞。通常我們提及得更多的是面向對象編程,面向對象編程是對數據的抽象(各種各樣的POJO類),而函數式編程則是對行為的抽象(將行為作為一個參數進行傳遞)。在JavaScript中這是很常見的一個語法特性,但在Java中將一個函數作為參數傳遞這卻行不通,好在JDK8的出現打破了Java的這一限制。

認識Lambda表達式

首先來引入一個示例,不知給是否有在IDEA編寫代碼的經歷,如果在JDK8的環境下如下所示按照Java傳統的語法規則編寫一個線程。

 new Thread(new Runnable() {
     @Override
     public void run() {
         System.out.println("Hello World!");
     }
 });

IDEA會給出提示可以使用Lambda表達式替換。

使用Lambda表達式則只需要使用一句話就可代替上面使用匿名類的方式

new Thread(() -> System.out.println("Hello World!"));

在這個例子中,傳統的語法規則,我們是將一個匿名內部類作為參數進行傳遞,我們實現了Runnable接口,并將其作為參數傳遞給Thread類,這實際上我們傳遞的是一段代碼,也即我們將代碼作為了數據進行傳遞,這就帶來許多不必要的“樣板代碼”。

Lambda表達式一共有三部分組成:

后面的示例中我們會詳解這個結構,包括有無參數,有無返回值的問題。那么這個看起來奇奇怪怪的不太像Java的語法規則,其本身含義到底什么呢?這也是開始困擾我的問題,什么時候在什么場景下可以使用Lambda表達式。

能夠接收Lambda表達式的參數類型,是一個只包含一個方法的接口。只包含一個方法的接口稱之為“函數接口”。

例如上面創建一個線程的示例,Runnable接口只包含一個方法,所以它被稱為“函數接口”,所以它可以使用Lambad表達式來代替匿名內部類。根據這個規則,我們試著來寫一個函數接口,并使用Lambda表達式作為參數傳遞。

package com.coderbuff.custom;

/**
 * 函數接口:只有一個方法的接口。作為Lambda表達式的類型
 * Created by Kevin on 2018/2/17.
 */
public interface FunctionInterface {
    void test();
}

測試:

package com.coderbuff.custom;

import org.junit.Test;

/**
 * 函數接口測試
 * Created by Kevin on 2018/2/17.
 */
public class FunctionInterfaceTest {

    @Test
    public void testLambda() {
        func(new FunctionInterface() {
            @Override
            public void test() {
                System.out.println("Hello World!");
            }
        });
        //使用Lambda表達式代替上面的匿名內部類
        func(() -> System.out.println("Hello World"));
    }

    private void func(FunctionInterface functionInterface) {
        functionInterface.test();
    }
}

可以看到,只要是一個接口中只包含一個方法,則可以使用Lambda表達式,這樣的接口稱之為“函數接口”。

上面的函數接口比較簡單不包含參數,也不包含返回值。

我們再來修改FunctionInterface函數接口逐步加大Lambda表達式的難度——包含參數,不包含返回值。

package com.coderbuff.custom;

/**
 * 函數接口:只有一個方法的接口。作為Lambda表達式的類型
 * Created by Kevin on 2018/2/17.
 */
public interface FunctionInterface {
    void test(int param);
}

測試:

package com.coderbuff.custom;

import org.junit.Test;

/**
 * 函數接口測試
 * Created by Kevin on 2018/2/17.
 */
public class FunctionInterfaceTest {

    @Test
    public void testLambda() {
        //使用Lambda表達式代替匿名內部類
        func((x) -> System.out.println("Hello World" + x));
    }

    private void func(FunctionInterface functionInterface) {
        int x = 1;
        functionInterface.test(x);
    }
}

關注Lambda表達式“(x)->Sysout.out.println("Hello World"+x)”,左邊傳遞的是參數,此處并沒有指明參數類型,因為它可以通過上下文進行類型推導,但在有些情況下不能推導出參數類型(在編譯時不能推導通常IDE會提示),此時則需要指明參數類型。我個人建議,任何情況下指明函數的參數類型。

哪種情況不能推導出參數類型呢?就是函數接口是一個泛型的時候。

package com.coderbuff.custom;

/**
 * 函數接口:只有一個方法的接口。作為Lambda表達式的類型
 * Created by Kevin on 2018/2/17.
 */
public interface FunctionInterface<T> {
    void test(T param);
}

測試:

package com.coderbuff.custom;

import org.junit.Test;

/**
 * 函數接口測試
 * Created by Kevin on 2018/2/17.
 */
public class FunctionInterfaceTest {

    @Test
    public void testLambda() {
        //使用Lambda表達式代替匿名內部類
        func((Integer x) -> System.out.println("Hello World" + x));
    }

    private void func(FunctionInterface<Integer> functionInterface) {
        int x = 1;
        functionInterface.test(x);
    }
}

上面的示例提到了Lambda表達式的兩種情況:

無參數,無返回值;

有參數,無返回值。

接下來就是有參數,有返回值這種較為復雜的情況。

package com.coderbuff.custom;

/**
 * 函數接口:只有一個方法的接口。作為Lambda表達式的類型
 * Created by Kevin on 2018/2/17.
 */
public interface FunctionInterface<T> {
    boolean test(T param);
}

測試:

package com.coderbuff.custom;

import org.junit.Test;

/**
 * 函數接口測試
 * Created by Kevin on 2018/2/17.
 */
public class FunctionInterfaceTest {

    @Test
    public void testLambda() {
        //使用Lambda表達式代替匿名內部類
        func((Integer x) -> true);
    }

    private void func(FunctionInterface<Integer> functionInterface) {
        int x = 1;
        functionInterface.test(x);
    }
}

此時的Lambda表達式“(Integer x) -> true”,右邊是表達式的主體,直接返回true,如果有多行代碼,則可以直接使用花括號表示,例如:

func((Integer x) -> {
    System.out.println("Hello World" + x);
    return true;
});

Lambda表達式基本的語法規則:

無參數,無返回值;

有參數,無返回值;

有參數,有返回值。

這三種基本情況已經大致清楚了,特別是需要弄清,什么時候可以使用Lambda表達式代替匿名內部類,也就是Lambda表達式的應用場景是函數接口。Lambda表達式這一新特性在JDK8中的引入,更大的好處則是集合API的更新,新增的Stream類庫,使得我們在遍歷使用集合時不再像以往那樣不斷地使用for循環。

JDK8使用集合的正確姿勢

示例:計算來自“chengdu”的學生數量有多少。

在JDK8前的代碼:

for (Student student : studentList) {
    if (student.getCity().equals("chengdu")) {
        count++;
    }
}

JDK8使用集合的正確姿勢:

count = studentList.stream().filter((student -> student.getCity().equals("chengdu"))).count();

API的使用“難度”恰似提高了,實際只是不熟悉而已。傳統迭代的方式需要閱讀完整個循環才能明白代碼邏輯,JDK8通過流的方式則可以望文生義且代碼量大大減小。

以上就是動力節點小編介紹的"JDK8的新特性詳解",希望對大家有幫助,想了解更多可查看Java8新特性技術文檔,如有疑問,請在線咨詢,有專業老師隨時為您服務。

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 干天天| 久久亚洲精品中文字幕三区 | 黄色三级日韩 | 15yc宅男影院在线观看 | 久草视频精品 | 日本国内一区二区三区 | 宅男深夜免费必看 | 日本片免费观看一区二区 | aa级黄色毛片 | 日韩一区二区三区不卡 | 日韩黄色三级视频 | 成人在线网 | 看一级| 久久久久久久网站 | 日本黄色片在线 | 国产日韩在线视频 | 伊人情涩网 | 99视频精品全部国产盗摄视频 | 色综合久久天天综合绕观看 | 羞羞视频官网 | 麻豆国内精品欧美在线 | 成年男女免费视频网站 | 一级做a爱过程免费视频时看 | 亚洲一级视频在线观看 | 国产日韩欧美另类重口在线观看 | 最近最新中文字幕高清免费 | 天天摸天天揉天天碰天天弄 | 二区久久国产乱子伦免费精品 | 一级黄色录像毛片 | 久久久久久久九九九九 | 亚洲一区精品在线 | 高清波多野结衣一区二区三区 | 日韩黄漫啪啪免费动漫 | 一级做一级爱a做片性视频视频 | 午夜成年人视频 | 国产福利小视频 | 97精品伊人久久久大香线蕉 | 夜色影院在线观看 | 国产精品成人免费视频不卡 | 亚洲国产精久久小蝌蚪 | 成年人福利 |