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

      如今開始要灌輸一些概念性的東西了,這能幫助你理解lambda更加透徹一點,若是你以前據說過,也可當是溫習,所謂溫故而知新......
html

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

函數式接口

函數式接口(functional interface 也叫功能性接口,實際上是同一個東西)。簡單來講,函數式接口是隻包含一個方法的接口。好比Java標準庫中的java.lang.Runnable和java.util.Comparator都是典型的函數式接口。java 8提供 @FunctionalInterface做爲註解,這個註解是非必須的,只要接口符合函數式接口的標準(即只包含一個方法的接口),虛擬機會自動判斷,但 最好在接口上使用註解@FunctionalInterface進行聲明,以避免團隊的其餘人員錯誤地往接口中添加新的方法。
Java中的lambda沒法單獨出現,它須要一個函數式接口來盛放,lambda表達式方法體其實就是函數接口的實現,下面講到語法會講到
ide

Lambda語法

包含三個部分函數

  1. 一個括號內用逗號分隔的形式參數,參數是函數式接口裏面方法的參數測試

  2. 一個箭頭符號:->大數據

  3. 方法體,能夠是表達式和代碼塊,方法體函數式接口裏面方法的實現,若是是代碼塊,則必須用{}來包裹起來,且須要一個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

通常方法的引用格式是

  1. 若是是靜態方法,則是ClassName::methodName。如 Object ::equals

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

  3. 構造函數.則是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表達式的最強做用的神祕面紗。敬請期待。。。。

若是你有建議或者疑問,歡迎在評論裏面留言

相關文章
相關標籤/搜索