Java11 發佈了,然而不少公司還在用Java 8 ,本文會簡要介紹Java 9 -11 引入的新語法和API。java
Java 10 就已經引入了新關鍵詞var,該關鍵詞能夠在聲明局部變量的時候替換類型信息。本地(local)是指方法內的變量聲明。react
Java 10以前,你須要這樣聲明一個String對象。數組
在Java10裏頭可使用var替代String,表達式變成這樣:異步
用var聲明的變量仍然是靜態類型的。 不兼容的類型沒法從新分配給此類變量。 此代碼段沒法編譯:post
當編譯器沒法推斷出正確的變量類型時,也不容許使用var。 如下全部代碼示例都會致使編譯器錯誤:spa
局部變量類型推斷能夠泛型。 在下一個示例中,Map.net
從Java 11開始,lambda參數也容許使用var關鍵字:線程
Java 9開始引入HttpClient API來處理HTTP請求。 從Java 11開始,這個API正式進入標準庫包(java.net)。 讓咱們來探索一下咱們能夠用這個API作些什麼。3d
新的HttpClient能夠同步或異步使用。 同步請求會阻止當前線程。 BodyHandlers定義響應體的預期類型(例如,字符串,字節數組或文件):code
也可使用異步來執行相同的請求。 調用sendAsync不會阻止當前線程,而是返回CompletableFuture來進行異步操做。
咱們能夠省略.GET,由於它是默認的請求方法。
下一個示例經過POST將數據發送到給定的URL。 與BodyHandler相似,您使用BodyPublishers定義做爲請求主體發送的數據類型,如字符串,字節數組,文件或輸入流:
最後一個例子演示瞭如何經過BASIC-AUTH執行受權:
List,Set和Map等集合已經用新方法擴展。 List.of從給定的參數建立了一個新的不可變列表。 List.copyOf建立列表的不可變副本。
由於list已是不可變的,因此實際上不須要實際建立list實例的副本,所以list和副本是相同的實例。 可是,若是你複製一個可變list,那麼複製確實會生成一個新實例,所以保證在改變原始list時沒有反作用:
建立不可變map時,您沒必要本身建立map條目,而是將鍵和值做爲參數傳遞:
Java 11中的不可變集合仍然使用Collection API中的老接口。 可是,若是嘗試修改不可變集合,則會拋出java.lang.UnsupportedOperationException。 可喜的是,若是嘗試改變不可變集合,Intellij IDEA會經過發出警告。
Streams是在Java 8中引入的,Java 9增長了三個新方法。 單個參數構造方法:
增長 takeWhile 和 dropWhile 方法,用於從stream中釋放元素:
若是對Stream不熟,能夠參考這篇文章[1]。
Optionals提供了一些很是方便的功能,例如 您如今能夠簡單地將Optional轉換爲Stream,或者爲空Optinal提供另外一個Optional做爲備胎:
Java11 給String增長了一些輔助方法來修剪或檢查空格等功能:
InputStream增長了transferTo方法,能夠用來將數據直接傳輸到 OutputStream:
從Java 8 到 Java 11引入了不少新特性,如下是這些特性的列表:
原文地址:
https://winterbe.com/posts/2018/09/24/java-11-tutorial/