<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                # 一、通往lambda之路:語法篇 > 來源:[Java 8新特性探究(一)通往lambda之路 語法篇](http://my.oschina.net/benhaile/blog/175012) 現在開始要灌輸一些概念性的東西了,這能幫助你理解lambda更加透徹一點,如果你之前聽說過,也可當是溫習,所謂溫故而知新…… 在開始之前,可以同步下載jdk 8 和 IDE,IDE根據個人習慣了,不過[Eclipse](http://res.importnew.com/eclipse "Eclipse ImportNew主頁")官方版本還沒出來,所以目前看的話,netbean7.4是首選的,畢竟前段子剛剛出的正式版本,以下是他們的下載地址。 * jdk 8:[https://jdk8.java.net/download.html](https://jdk8.java.net/download.html) (畢竟是國外的網站,如果下載慢,可以到我的云盤下載[http://pan.baidu.com/share/link?shareid=61064476&uk=4060588963](http://pan.baidu.com/share/link?shareid=61064476&uk=4060588963)) * Netbeans 7.4正式版:[https://netbeans.org/downloads/](https://netbeans.org/downloads/)(推薦,oracle官方發布) * IDEA 12 EAP:[http://confluence.jetbrains.net/display/IDEADEV/IDEA+12+EAP](http://confluence.jetbrains.net/display/IDEADEV/IDEA+12+EAP) * Unofficial builds of Eclipse:[http://downloads.efxclipse.org/eclipse-java8/](http://my.oschina.net/benhaile/admin/:http:/downloads.efxclipse.org/eclipse-java8) ### **函數式接口** 函數式接口(functional interface 也叫功能性接口,其實是同一個東西)。簡單來說,函數式接口是只包含一個方法的接口。比如Java標準庫中的java.lang.Runnable和java.util.Comparator都是典型的函數式接口。java 8提供 @FunctionalInterface作為注解,這個注解是非必須的,只要接口符合函數式接口的標準(即只包含一個方法的接口),虛擬機會自動判斷,但 最好在接口上使用注解@FunctionalInterface進行聲明,以免團隊的其他人員錯誤地往接口中添加新的方法。 Java中的lambda無法單獨出現,它需要一個函數式接口來盛放,lambda表達式方法體其實就是函數接口的實現,下面講到語法會講到 ### **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表達式的最強作用的神秘面紗。敬請期待。。。。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看