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

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

JDK8的新特性詳解

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

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新特性技術文檔,如有疑問,請在線咨詢,有專業老師隨時為您服務。

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

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 天天槽夜夜槽槽不停 | 日本日批视频 | 久久狠色噜噜狠狠狠狠97 | 免费在线h| 久久久久亚洲日日精品 | 五月香婷 | 日韩娇小性hd | 免费看的一级毛片 | 精品成人免费一区二区在线播放 | 污污网站免费入口链接 | 欧美日韩在线视频播放 | 韩国在线观看免费观看影院 | 野外三级国产在线观看 | 在线播放h | 中文字幕日本在线mv视频精品 | 一区二区三区免费在线观看 | 久久免费区一区二区三波多野 | 黄漫画黄网站在线观看 | 久草一级片 | 欧美精品一区二区三区在线播放 | 色六月婷婷 | 在线观看欧美日韩 | 亚洲日本va | 午夜官网| 午夜欧美成人久久久久久 | 国产一区二区三区亚洲欧美 | 伊人网综合视频 | 一区二区不卡免费视频 | 中国国产高清一级毛片 | 国产成人精品高清在线观看99 | 免费观看色视频 | 精产国品一区 | 日本三级香港三级国产三级 | 永久免费观看午夜视频在线 | 久久久久久久国产a∨ | 白丝美女私视频 | 欧美国产伦久久久久 | 一二三区在线观看 | 亚洲专区一| 国产国语高清在线视频二区 | 日韩精品综合 |