現在開始要灌輸一些概念性的東西了,這能幫助你理解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,則無需{}
總體看起來像這樣
1 |
(parameters) -> expression 或者 (parameters) -> { statements; } |
看一個完整的例子,方便理解
06 |
public class TestLambda { |
08 |
public static void runThreadUseLambda() { |
11 |
new Thread(() ->System.out.println( "lambda實現的線程" )).start(); |
14 |
public static void runThreadUseInnerClass() { |
16 |
new Thread( new Runnable() { |
19 |
System.out.println( "內部類實現的線程" ); |
24 |
public static void main(String[] args) { |
25 |
TestLambda.runThreadUseLambda(); |
26 |
TestLambda.runThreadUseInnerClass(); |
可以看出,使用lambda表達式設計的代碼會更加簡潔,而且還可讀。
方法引用
其實是lambda表達式的一個簡化寫法,所引用的方法其實是lambda表達式的方法體實現,語法也很簡單,左邊是容器(可以是類名,實例名),中間是"::",右邊是相應的方法名。如下所示:
1 |
ObjectReference::methodName |
一般方法的引用格式是
-
如果是靜態方法,則是ClassName::methodName。如 Object ::equals
-
如果是實例方法,則是Instance::methodName。如Object obj=new Object();obj::equals;
-
構造函數.則是ClassName::new
再來看一個完整的例子,方便理解
01 |
import java.awt.FlowLayout; |
02 |
import java.awt.event.ActionEvent; |
03 |
import javax.swing.JButton; |
04 |
import javax.swing.JFrame; |
10 |
public class TestMethodReference { |
12 |
public static void main(String[] args) { |
14 |
JFrame frame = new JFrame(); |
15 |
frame.setLayout( new FlowLayout()); |
16 |
frame.setVisible( true ); |
18 |
JButton button1 = new JButton( "點我!" ); |
19 |
JButton button2 = new JButton( "也點我!" ); |
21 |
frame.getContentPane().add(button1); |
22 |
frame.getContentPane().add(button2); |
25 |
button1.addActionListener(e -> { System.out.println( "這裏是Lambda實現方式" ); }); |
27 |
button2.addActionListener(TestMethodReference::doSomething); |
31 |
* 這裏是函數式接口ActionListener的實現方法 |
34 |
public static void doSomething(ActionEvent e) { |
36 |
System.out.println( "這裏是方法引用實現方式" ); |
可以看出,doSomething方法就是lambda表達式的實現,這樣的好處就是,如果你覺得lambda的方法體會很長,影響代碼可讀性,方法引用就是個解決辦法
總結
以上就是lambda表達式語法的全部內容了,相信大家對lambda表達式都有一定的理解了,但只是代碼簡潔了這個好處的話,並不能打動很多觀衆,java 8也不會這麼令人期待,其實java 8引入lambda迫切需求是因爲lambda 表達式能簡化集合上數據的多線程或者多核的處理,提供更快的集合處理速度 ,這個後續會講到,關於JEP126的這一特性,將分3部分,之所以分開,是因爲這一特性可寫的東西太多了,這部分讓讀者熟悉lambda表達式以及方法引用的語法和概念,第二部分則是虛擬擴展方法(default
method)的內容,最後一部分則是大數據集合的處理,解開lambda表達式的最強作用的神祕面紗。敬請期待。。。。
如果你有建議或者疑問,歡迎在評論裏面留言
原文出處
http://my.oschina.net/benhaile