Java 9 在 9 月 21 日 正式發佈 ,同時 Oracle 宣佈將 Java 新版本的 發佈周期調整為每半年一次。目前,Java 新版本的開發也已正式進入軌道。就已公開的消息來看,下一個版本的 Java 預計會在 2018 年 3 月發佈,版本號將會是 18.3 ,已經規劃加入的特性包括 J ...
Java 9 在 9 月 21 日 正式發佈 ,同時 Oracle 宣佈將 Java 新版本的 發佈周期調整為每半年一次。目前,Java 新版本的開發也已正式進入軌道。就已公開的消息來看,下一個版本的 Java 預計會在 2018 年 3 月發佈,版本號將會是 18.3 ,已經規劃加入的特性包括 JEP 286 和 296。
根據 reddit 站點上的 討論 ,首先更新的是 JEP 296,Valhalla 預計很快也會加入進來。OpenJDK 的 主頁面 則顯示,已確定要在 18.3 版本實現的是 JEP 286 和 296。
JEP 296 主要是將 JDK 倉庫群(JDK Repository Forest)合併為一個倉庫,旨在降低管理大量倉庫群的成本。根據 InfoQ 之前的 報道 ,該倉庫群的合併已經完成。這些軟體倉庫是在 OpenJDK 發展史上歷次分裂生成的,在 OpenJDK 9 及以前的版本中將會繼續存在。在這次合併操作之前,OpenJDK 曾分裂為多個不同的 Mercurial 軟體倉庫群,這導致了許多問題,例如不能以原子方式對多個軟體倉庫應用漏洞修複(Bug Fixes)。在 OpenJDK 合併完成後,只會有一個軟體倉庫,並複製在三個開發線上。為了簡化倉庫的管理,JDK 中還創建了用於在合併和未合併版本間 移動更改的工具 。
JEP 286 提議在 Java 中引入局部變數的類型推斷,該 JEP 在 2016 年提出,InfoQ 曾經報道過該 JEP 的 概況 和相關的開發者 調查結果 。該 JEP 旨在減少編寫 Java 代碼相關的儀式性的內容,提升開發人員的體驗,同時還要保證 Java 語言的靜態性。它會減少開發人員在聲明局部變數時,沒有必要的變數類型聲明。如果該 JEP 實現的話,在聲明局部變數的時候,就可以採用類似如下的方式:
var list = new ArrayList(); // infers ArrayList
var stream = list.stream(); // infers Stream
這種語句只能用於帶有初始化器(initializer)的局部變數、增強的 for-loop 中的索引以及傳統 for-loop 中聲明的局部變數。它不能用於方法聲明、構造函數聲明、方法返回值、欄位、catch 語句以及其他類型的變數聲明中。
關於局部變數的類型推斷,不管是 JVM 體系中的語言還是其他語言都提供了一定形式的支持,比如 C++(auto)、C#(var)、Scala(var/val)以及 Go(通過:=進行聲明)。至於該使用 var 作為關鍵字,還是使用 let 或類似於 C/C++中的 auto 作為關鍵字,之前曾經有過一個面向開發者的調查。大約 84%的回答表明定義可變內容的變數用關鍵字 var 是恰當的,只有百分之幾的回答者建議使用 auto 更合適。根據 Java 語言架構師 Brian Goetz 介紹,該功能應該使用關鍵詞 var。
關於該特性的用法,在 reddit 上有一些討論。有人表示,即便在支持“auto”語法的語言中,該特性使用的也比較少,因為有些人希望一眼就能看出變數的類型是什麼。也有人認為,var 有它的適用空間,在小的代碼塊中,直接用它實例化對象是可以的。如果是作為方法返回值的話,還是希望明確聲明類型,Java 的類型推斷並不支持方法返回值,這一點倒不必擔心。如果函數或代碼塊比較長的話,就不建議使用 var 了並要考慮適時進行代碼的重寫。時間和經驗將會讓我們更加明確應該在何時使用新功能,就像 Optional 剛出現時,也是耗費了一些時間才明確其推薦適用場景。
Valhalla 項目 中包含了一些有趣的 JEP,包括 值類型 (Value Type)、 針對原始類型實現泛型功能 、 增強的 volatile 等,外界很期待這些內容最終也能添加到新版本中。
歡迎加入學習交流群569772982,大家一起學習交流。