摘要:歐陽思海繼承接口后,又加了新的抽象方法,這個(gè)接口就不再是函數(shù)式接口默認(rèn)方法在接口中添加了一個(gè)默認(rèn)方法。總結(jié)在這篇文章中,我們講了表達(dá)式方法引用函數(shù)式接口接口中的靜態(tài)方法接口中的默認(rèn)方法的使用。
今天我來聊聊 Java8 的一些新的特性,確實(shí) Java8 的新特性的出現(xiàn),給開發(fā)者帶來了非常大的便利,可能剛剛開始的時(shí)候會(huì)有點(diǎn)不習(xí)慣的這種寫法,但是,當(dāng)你真正的熟悉了之后,你一定會(huì)愛上這些新的特性的,這篇文章就來聊聊這些新特性。
lambda 表達(dá)式lambda 表達(dá)式在項(xiàng)目中也是用到了,這種新的語法的加入,對(duì)于使用 Java 多年的我,我覺得是如虎添翼的感覺哈,這種新的語法,大大的改善了以前的 Java 的代碼,變得更加的簡潔,我覺得這也是為什么 Java8 能夠很快的流行起來的原因吧。
這里我們用幾個(gè)以前的經(jīng)典的 Java 的寫法和用 lambda 表達(dá)式的方式進(jìn)行對(duì)比。
線程的用法
原始的線程用法
//使用匿名內(nèi)部類的方式啟動(dòng)多線程 new Thread(new Runnable() { @Override public void run() { System.out.println("這是使用匿名內(nèi)部類的方式。。。"); } }).start();
lambda 表達(dá)式
//使用lambda表達(dá)式方式 new Thread(() -> { System.out.println("這是使用lambda表達(dá)式的方式。。。"); }).start();
你會(huì)發(fā)現(xiàn),用 lambda 表達(dá)式的方式能夠?qū)懜俚拇a,看起來也會(huì)更加的舒服和簡潔。
這里沒有使用參數(shù),只是一個(gè)簡單的例子。
我們?cè)倏匆粋€(gè)例子。
遍歷方式
原始方式
//原始方式 Listlist = Arrays.asList(1, 2, 3, 4, 5); for (int i : list) { System.out.println(i); }
lambda 表達(dá)式方式
//使用lambda表達(dá)式代替foreach循環(huán) Stream.of(1, 2, 3, 4, 5).forEach((x) -> { System.out.println(x); });
在原始的方式中,我們一般使用 foreach 的方式進(jìn)行遍歷,有了 Java8 的方式之后,我們可以用 forEach 方法,然后,再用 lambda 表達(dá)式的方式進(jìn)行遍歷,也讓原來的方式變得更加的簡潔。
在這個(gè)例子中,我們加了一個(gè)參數(shù),在()中間我們加了一個(gè) x ,代表的意思其實(shí)是:通過 forEach 方法,我們把一個(gè)元素已經(jīng)賦值到 x 中了,拿到這個(gè) x ,我們就可以輸出結(jié)果。
總結(jié)
lambda 的使用方式其實(shí)很簡單,可以總結(jié)為下面的方法。
([參數(shù)可選,...]) -> { }方法引用
方法引用其實(shí)是 lambda 表達(dá)式的部分的簡化,也就是為了簡化 lambda 表達(dá)式而存在的感覺,下面我們還講講怎么使用方法引用。
/** * @return void * @Author ouyangsihai * @Description 方法引用測試 * @Date 10:23 2019/5/14 * @Param [] **/ @Test public void test_method_reference() { //使用lambda表達(dá)式 Stream.of("A", "BB", "CCC", "DDDD", "FFFFF") .map(s -> s.length()) //lambda .forEach((x) -> { System.out.println(x); }); //使用靜態(tài)方法引用 Stream.of("A", "BB", "CCC", "DDDD", "FFFFF") .map(String::length) //靜態(tài)方法引用 .forEach((x) -> { System.out.println(x); }); //使用實(shí)例方法引用 Stream.of( new ClassMate("1", "歐陽思海"), new ClassMate("2", "sihai") ).map(ClassMate::getName)//實(shí)例方法引用 .forEach(x -> { System.out.println(x); }); }
在第一個(gè)測試中,我們用的是 lambda 表達(dá)式來獲取每個(gè)字符串的長度。
s -> s.length()
在第二個(gè)測試中,我們使用的是靜態(tài)方法引用來獲取每個(gè)字符串的長度。
String::length
在第三個(gè)測試中,我們使用的是實(shí)例方法引用。
ClassMate::getName
解釋
① map 方法是映射的意思。
② forEach 方式是遍歷每一個(gè)元素。
③ ClassMate 是一個(gè)包含 id 和 name 的簡單 po 類。
通過上面這個(gè)例子,基本上我們就知道怎么使用方法引用了。下面我們進(jìn)行一個(gè)小的總結(jié)。
總結(jié)
① 使用方法
類名::方法名
② 方法可以是:靜態(tài)方法,實(shí)例方法
構(gòu)造函數(shù)引用在上面我們講了方法引用的基本使用方法,其實(shí)除了方法引用以外,還有構(gòu)造函數(shù)引用,回想一下,以前我們創(chuàng)建對(duì)象是怎么做?是不是需要 new 一個(gè)對(duì)象呢,那么現(xiàn)在用構(gòu)造函數(shù)引用又是怎么做的呢?
下面我們用一個(gè)例子講解一下,在這個(gè)例子中,對(duì)象還是使用上面的 ClassMate。
/** * @return void * @Author ouyangsihai * @Description 構(gòu)造函數(shù)引用測試 * @Date 10:23 2019/5/14 * @Param [] **/ @Test public void test_method_reference2() { //使用lambda表達(dá)式 Stream.of("A", "BB", "CCC", "DDDD", "FFFFF") .map(s -> new ClassMate(s)) //lambda .collect(Collectors.toList()); //使用構(gòu)造函數(shù)引用 Stream.of("A", "BB", "CCC", "DDDD", "FFFFF") .map(ClassMate::new) //構(gòu)造函數(shù)引用,由上下文決定用哪一個(gè)構(gòu)造函數(shù) .collect(Collectors.toList()); }
① 第一個(gè)我們使用的是 lambda 表達(dá)式進(jìn)行創(chuàng)建對(duì)象的 s -> new ClassMate(s)。
② 第二個(gè)我們使用的是構(gòu)造函數(shù)引用創(chuàng)建對(duì)象的 ClassMate::new 。
③ 我們發(fā)現(xiàn)構(gòu)造函數(shù)引用:類名::new ,然后對(duì)于使用哪一個(gè)構(gòu)造函數(shù)是由上下文決定的,比如有一個(gè)參數(shù)和兩個(gè)參數(shù)和無參數(shù)的構(gòu)造函數(shù),會(huì)自動(dòng)確定用哪一個(gè)。
在 Java 8 之前的接口是不能有實(shí)現(xiàn)的,只能定義抽象方法,然而,在 Java 8 以后,增加了一個(gè)新的功能,可以添加實(shí)現(xiàn),可以定義默認(rèn)方法,可以定義靜態(tài)方法。
函數(shù)式接口什么是函數(shù)式接口呢?
這個(gè)名詞在 Java 中以前是很少聽到的,但是正是有了 Java 8 的橫空出世,函數(shù)式編程也變得熟悉了。
在一個(gè)接口中我們以 @FunctionalInterface 注解聲明一個(gè)接口,并且接口中只有一個(gè)抽象方法,那么我們就叫做這是一個(gè)函數(shù)式接口。
/** * @ClassName FunctionalInterfaceTest * @Description * @Author 歐陽思海 * @Date 2019/5/14 10:39 * @Version 1.0 **/ @FunctionalInterface public interface FunctionalInterfaceTest { //繼承接口后,又加了新的抽象方法,這個(gè)接口就不再是函數(shù)式接口 void test(String s); }
① 上面的接口中只有一個(gè)抽象方法,所以這是一個(gè)函數(shù)式接口。
② 如果上面接口中再加一個(gè)抽象方法,那么就不是函數(shù)式接口了。
下面,我們?cè)偻ㄟ^繼承來繼承這個(gè)接口。
/** * @ClassName FunctionalTest * @Description * @Author 歐陽思海 * @Date 2019/5/17 17:26 * @Version 1.0 **/ public interface FunctionalTest extends FunctionalInterfaceTest{ int test2(); }
① 我們繼承了上面的接口,并且加了一個(gè) test2 方法。
② 這里注意,如果一個(gè)接口集成現(xiàn)有的函數(shù)式接口后,又加了其他的抽象方法,這個(gè)接口就不是函數(shù)式接口了。
默認(rèn)方法很簡單,用 default 聲明即可。
/** * @ClassName FunctionalInterfaceTest * @Description * @Author 歐陽思海 * @Date 2019/5/14 10:39 * @Version 1.0 **/ @FunctionalInterface public interface FunctionalInterfaceTest { //繼承接口后,又加了新的抽象方法,這個(gè)接口就不再是函數(shù)式接口 void test(String s); //默認(rèn)方法 default String getStr(){ return null; } }
① 在接口中添加了一個(gè)默認(rèn)方法。并且實(shí)現(xiàn)了方法。
靜態(tài)方法默認(rèn)方法很簡單,用 static 聲明即可。
/** * @ClassName FunctionalInterfaceTest * @Description * @Author 歐陽思海 * @Date 2019/5/14 10:39 * @Version 1.0 **/ @FunctionalInterface public interface FunctionalInterfaceTest { //繼承接口后,又加了新的抽象方法,這個(gè)接口就不再是函數(shù)式接口 void test(String s); //靜態(tài)方法 static String getStr2(){ return null; } //錯(cuò)誤用法 default static String getStr3(){ return null; } }
① 實(shí)現(xiàn)的靜態(tài)方法,用 static 聲明。
② 注意不能同時(shí)使用 default 和 static 聲明。
在這篇文章中,我們講了 lambda 表達(dá)式、方法引用、函數(shù)式接口、接口中的靜態(tài)方法、接口中的默認(rèn)方法的使用。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/74858.html
摘要:上一篇小樂介紹了新特性函數(shù)式接口,大家可以點(diǎn)擊回顧。中引入方法引用新特性用于簡化應(yīng)用對(duì)象方法的調(diào)用,方法引用是用來直接訪問類或者實(shí)例的已經(jīng)存在的方法或者構(gòu)造方法。方法引用是一種更簡潔易懂的表達(dá)式。 上一篇小樂介紹了《Java8新特性-函數(shù)式接口》,大家可以點(diǎn)擊回顧。這篇文章將接著介紹Java8新特性之方法引用。 Java8 中引入方法引用新特性,用于簡化應(yīng)用對(duì)象方法的調(diào)用,?方法引用是...
摘要:大家好,我是樂字節(jié)的小樂,上一次我們說到了核心特性之函數(shù)式接口,接下來我們繼續(xù)了解又一核心特性方法引用。方法引用是一種更簡潔易懂的表達(dá)式。感謝光臨閱讀小樂的,敬請(qǐng)關(guān)注樂字節(jié)后續(xù)將繼續(xù)講述等前沿知識(shí)技術(shù)。 大家好,我是樂字節(jié)的小樂,上一次我們說到了Java8核心特性之函數(shù)式接口,接下來我們繼續(xù)了解Java8又一核心特性——方法引用。 showImg(https://segmentfaul...
摘要:實(shí)際上方法引用是表達(dá)式的一種語法糖。小結(jié)本篇全面介紹了方法引用的四種使用方式,且每種方式都有對(duì)應(yīng)一個(gè)示例來幫助大家理解。 上一篇我們?cè)敿?xì)介紹了Optional類用來避免空指針問題,本篇我們?nèi)媪私庖幌翵ava8中的方法引用特性。方法引用是lambda表達(dá)式的一種特殊形式,如果正好有某個(gè)方法滿足一個(gè)lambda表達(dá)式的形式,那就可以將這個(gè)lambda表達(dá)式用方法引用的方式表示,但是如果這...
摘要:一表達(dá)式匿名內(nèi)部類最大的問題在于其冗余的語法,比如前面的中五行代碼僅有一行是在執(zhí)行任務(wù)。總結(jié)基于詞法作用域的理念,表達(dá)式不可以掩蓋任何其所在上下文的局部變量。 轉(zhuǎn)載請(qǐng)注明出處:https://zhuanlan.zhihu.com/p/20540175 在介紹Lambda表達(dá)式之前,我們先來看只有單個(gè)方法的Interface(通常我們稱之為回調(diào)接口): public interface...
摘要:表達(dá)式體現(xiàn)了函數(shù)式編程的思想,即一個(gè)函數(shù)亦可以作為另一個(gè)函數(shù)參數(shù)和返回值,使用了函數(shù)作參數(shù)返回值的函數(shù)被稱為高階函數(shù)。對(duì)流對(duì)象進(jìn)行及早求值,返回值不在是一個(gè)對(duì)象。 Java8主要的改變是為集合框架增加了流的概念,提高了集合的抽象層次。相比于舊有框架直接操作數(shù)據(jù)的內(nèi)部處理方式,流+高階函數(shù)的外部處理方式對(duì)數(shù)據(jù)封裝更好。同時(shí)流的概念使得對(duì)并發(fā)編程支持更強(qiáng)。 在語法上Java8提供了Lamb...
閱讀 3406·2021-11-25 09:43
閱讀 3464·2021-11-19 09:40
閱讀 2464·2021-10-14 09:48
閱讀 1283·2021-09-09 11:39
閱讀 1920·2019-08-30 15:54
閱讀 2821·2019-08-30 15:44
閱讀 1994·2019-08-29 13:12
閱讀 1543·2019-08-29 12:59