java 8 新特性探究_Java 8新特性探究(一):通往lambda之路_語法篇

說到java 8,首先會想到lambda(閉包)以及虛擬擴展方法(default method),這個特性早已經被各大技術網站炒得沸沸揚揚了,也是我們java 8系列開篇要講的第一特性(JEP126 http://openjdk.java.net/jeps/126),jdk8的一些庫已經應用了lambda表達式重新設計了,理解他對學習java 8新特性有着重要的意義。

現在開始要灌輸一些概念性的東西了,這能幫助你理解lambda更加透徹一點,如果你之前聽說過,也可當是溫習,所謂溫故而知新……

在開始之前,可以同步下載jdk 8 和 IDE,IDE根據個人習慣了,不過eclipse官方版本還沒出來,所以目前看的話,netbean7.4是首選的,畢竟前段子剛剛出的正式版本,以下是他們的下載地址。

函數式接口

函數式接口(functional interface 也叫功能性接口,其實是同一個東西)。簡單來說,函數式接口是只包含一個方法的接口。比如Java標准庫中的java.lang.Runnable和 java.util.Comparator都是典型的函數式接口。java 8提供 @FunctionalInterface作為注解,這個注解是非必須的,只要接口符合函數式接口的標准(即只包含一個方法的接口),虛擬機會自動判斷, 但 最好在接口上使用注解@FunctionalInterface進行聲明,以免團隊的其他人員錯誤地往接口中添加新的方法。

Java中的lambda無法單獨出現,它需要一個函數式接口來盛放,lambda表達式方法體其實就是函數接口的實現,下面講到語法會講到。

Lambda語法

包含三個部分

一個括號內用逗號分隔的形式參數,參數是函數式接口里面方法的參數

一個箭頭符號:->

方法體,可以是表達式和代碼塊,方法體函數式接口里面方法的實現,如果是代碼塊,則必須用{}來包裹起來,且需要一個return 返回值,但有個例外,若函數式接口里面方法返回值是void,則無需{}總體看起來像這樣:(parameters) -> expression 或者 (parameters) -> { statements; }

看一個完整的例子,方便理解/**

* 測試lambda表達式

*

*@author benhail

*/

public class TestLambda {

public static void runThreadUseLambda() {

//Runnable是一個函數接口,只包含了有個無參數的,返回void的run方法;

//所以lambda表達式左邊沒有參數,右邊也沒有return,只是單純的打印一句話

new Thread(() ->System.out.println("lambda實現的線程")).start();

}

public static void runThreadUseInnerClass() {

//這種方式就不多講了,以前舊版本比較常見的做法

new Thread(new Runnable() {

@Override

public void run() {

System.out.println("內部類實現的線程");

}

}).start();

}

public static void main(String[] args) {

TestLambda.runThreadUseLambda();

TestLambda.runThreadUseInnerClass();

}

}

可以看出,使用lambda表達式設計的代碼會更加簡潔,而且還可讀。

方法引用

其實是lambda表達式的一個簡化寫法,所引用的方法其實是lambda表達式的方法體實現,語法也很簡單,左邊是容器(可以是類名,實例名),中間是”::”,右邊是相應的方法名。如下所示:ObjectReference::methodName

一般方法的引用格式是

如果是靜態方法,則是ClassName::methodName。如 Object ::equals

如果是實例方法,則是Instance::methodName。如Object obj=new Object();obj::equals;

構造函數.則是ClassName::new

再來看一個完整的例子,方便理解import java.awt.FlowLayout;

import java.awt.event.ActionEvent;

import javax.swing.JButton;

import javax.swing.JFrame;

/**

*

*@author benhail

*/

public class TestMethodReference {

public static void main(String[] args) {

JFrame frame = new JFrame();

frame.setLayout(new FlowLayout());

frame.setVisible(true);

JButton button1 = new JButton("點我!");

JButton button2 = new JButton("也點我!");

frame.getContentPane().add(button1);

frame.getContentPane().add(button2);

//這里addActionListener方法的參數是ActionListener,是一個函數式接口

//使用lambda表達式方式

button1.addActionListener(e -> { System.out.println("這里是Lambda實現方式"); });

//使用方法引用方式

button2.addActionListener(TestMethodReference::doSomething);

}

/**

* 這里是函數式接口ActionListener的實現方法

*@param e

*/

public static void doSomething(ActionEvent e) {

System.out.println("這里是方法引用實現方式");

}

}

可以看出,doSomething方法就是lambda表達式的實現,這樣的好處就是,如果你覺得lambda的方法體會很長,影響代碼可讀性,方法引用就是個解決辦法

總結

以上就是lambda表達式語法的全部內容了,相信大家對lambda 表達式都有一定的理解了,但只是代碼簡潔了這個好處的話,並不能打動很多觀眾,java 8也不會這么令人期待,其實java 8引入lambda迫切需求是因為lambda 表達式能簡化集合上數據的多線程或者多核的處理,提供更快的集合處理速度 ,這個后續會講到,關於JEP126的這一特性,將分3部分,之所以分開,是因為這一特性可寫的東西太多了,這部分讓讀者熟悉lambda表達式以及方法 引用的語法和概念,第二部分則是虛擬擴展方法(default method)的內容,最后一部分則是大數據集合的處理,解開lambda表達式的最強作用的神秘面紗。敬請期待。。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值