在屢次延期後,Java 9將於9月21日以Java開發工具包9的形式出現,這是自2014年3月以來,Java標準版的第一次重大升級。官方列出了JDK 9的大約90個新特性,模塊化是最主要的一個。將Java從新配置成模塊化格式,這項任務已經持續了多年,但在編譯、代碼緩存和JavaScript部署等領域也會有其餘改進。java
JDK 9的Java平臺模塊系統c++
Java 9最寶貴的特性,即模塊化——以Java平臺模塊系統的形式——旨在將JDK分爲運行、編譯或構建時的一組模塊。模塊化被稱爲「可傳遞」的變化,這能夠更好地理解跨模塊的依賴關係。瀏覽器
Java 9的模塊化方面包括應用程序打包、模塊化JDK以及將源代碼從新組織到模塊中。在構建時,構建系統將強化編譯模塊並增強模塊邊界。JDK和Java運行環境(JRE)的鏡像將被重構,以此來處理模塊。同時,JavaFX UI控件和CSS API也將被模塊化。緩存
JDK 9將支持許多配置,可伸縮性、安全性和應用程序性能也會獲得改進。將Java簡化爲小型設備是模塊化工做的關鍵。Java平臺模塊系統,是Jigsaw項目的一個組件,也將被實現。安全
經過模塊化,開發人員可以更好地爲Java SE(標準版)和EE(企業版)構建和維護大型應用程序。但Oracle、IBM、Red Hat和其餘公司關於如何在平臺上作出完全改變的問題上存在分歧。該模塊系統在5月曾被否認,但在6月進行了第二次投票後,纔得到批准。服務器
關於模塊化是否會對Java開發人員有着很大的好處,還存在爭議,一些專家表示同意,而另外一些專家則不贊同。但無論怎樣,Oracle一直在努力實現模塊化平臺。app
爲了實現模塊化,已經屢次延遲了Java 9的發佈,由於Oracle一直在嘗試更簡單地遷移到Java 9,而且計劃容許對類路徑上的代碼進行非法的反向訪問,同時JRE會使用它來搜索類和資源文件。此功能將在Java 9以後被禁用。框架
在Java 9的JDK中編譯模塊化
Java 9爲編譯代碼提供了幾種新功能,其中最主要的功能是提早編譯。這個功能仍然處於實驗階段,此功能容許在虛擬機啓動以前將Java類編譯爲本機代碼。該特性旨在提升小型和大型應用程序的啓動時間,同時對峯值性能幾乎沒有影響。工具
即時(JIT)編譯器速度很快,可是Java程序已經變得如此之大,以致於JIT須要很長時間才能徹底啓動,這使得一些Java方法沒法編譯,性能也愈來愈弱。提早進行編譯是爲了解決這些問題。
但Java技術供應商Excelsior的市場總監Dmitry Leskov擔憂,這種時間上的編譯技術還不夠成熟,並但願Oracle能在Java 10後再推出更可靠的版本。
Java 9還實現了Oracle智能編譯部署的第二階段。這個特性包括改進javac工具的穩定性和可移植性,以便在JVM(Java虛擬機)能默認使用它。該工具也將被推廣,所以它能夠用於JDK以外的大型項目。
另外一個新的實驗,編譯特性是java級別的JVM編譯器接口(JVMCI)。這個接口容許用Java編寫的編譯器被JVM用做動態編譯器。JVMCI的API提供了訪問VM結構、安裝編譯代碼和插入JVM編譯系統的機制。
用Java編寫的JVM編譯器應該須要一個高質量的編譯器,它比用C或c++編寫的現有編譯器更容易維護和改進。另外,現有支持Java編譯器的項目有Graal和Metropolis。
新的編譯器控制功能旨在控制JVM編譯器的細粒度和方法依賴,讓開發人員在運行時更改編譯器控制選項,而又不會形成性能降低。該工具還能夠爲JVM編譯器錯誤提供工做區。
Java 9的JDK還將更新javac編譯器,這樣它就能夠編譯Java 9程序,以運行在一些Java的舊版本上。
Java 9實現了REPL
Java 9將會有一個read-eval-print loop(REPL)工具——這是Java的另外一個長期目標,通過多年的Kulia項目開發以後,在這個版本中它將變得真實。
Java 9的REPL被稱爲jShell,它交互式地評估聲明語句和表達式。開發人員只需輸入一些代碼,就能夠在編譯以前得到對程序的反饋。
命令行工具的功能包括結束標籤和自動添加所需的終端分號。jShell API容許在IDE和其餘工具中使用jShell功能,儘管工具自己並非IDE。
人們認爲,缺少REPL工具是院校愈來愈不肯授課Java的一個緣由(Python和Scala等語言早就有REPL了)。Scala語言的創始人Martin Odersky質疑Java的REPL的實用性,他說Java是面向語句的,而REPL是面向表達式的。
JDK 9中實行代碼緩存分段
JDK 9容許將代碼緩存分紅幾個部分,以提升性能,並容許擴展(好比細粒度的鎖)。因爲專門的迭代器會跳過非方法代碼,因此掃描時間須要被提升。分離非方法、異形和非異形碼,提升一些基準測試的執行時間。
Java 9支持更多的標準
Java 9增長了對幾個標準的支持。
新的HTTP/2 client API實現了HTTP/2協議,同時升級到Web的核心HTTP協議和WebSocket協議,基於瀏覽器的交互式通訊。新的API能夠替代HttpURLConnection API,HttpURLConnection API的問題是它包含已經失效的協議predating HTTP/1,這個太抽象,很難使用。可是,在JDK 9發佈時,新的HTTP/2 API仍然處於beta測試階段。
JDK 9還增長了對HTML5的支持。Javadoc API文檔工具功能已經被加強,能夠生成HTML5標記。
Java 9還將支持Unicode 8.0編碼標準,該標準增長了8000個字符、10個模塊和6個腳本。
對於安全性,Java 9爲DTLS(數據包傳輸層安全性協議)添加了一個API。該協議的設計目的是防止在client/server通訊中出現竊聽、篡改和消息僞造,這將爲客戶端和服務器模式提供一個安全模式。
JDK 9得到了更多的JavaScript支持(Nashorn項目)
Nashorn項目是爲了能讓JavaScript在Java上進行高性能且輕量級的運行,這是在Rhino項目後的Netscape開始進行的。Nashorn項目負責在Java應用程序中嵌入JavaScript。其實在JDK 8中已經爲Java提供了一個JavaScript引擎。
JDK 9將包括一個用於ECMAScript語法樹的解析器API。API將經過IDE和服務器框架實現ECMAScript代碼分析,而不依賴於Nashorn項目的內部實現類。
Java 9棄用和移除了哪些功能
Java 9棄用和移除一些再也不流行的特性。其中最主要的是Applet API,它將被棄用。如今,安全瀏覽器已經取消了對Java瀏覽器插件的支持,由於這些已通過時了,HTML5的出現也加速了它們的滅亡。開發人員將轉向到諸如Java Web Start這樣的替代方案,用於在瀏覽器中啓動應用程序或者安裝應用程序。同時,appletviewer工具也被棄用了。
Java 9將棄用Concurrent Mark Sweep (CMS)垃圾收集器,並在將來的版本中中止支持它。其目的是加速在HotSpot虛擬機中的其餘垃圾收集器的開發。低暫停G1垃圾收集器將是CMS的長期替代品。
與此同時,JDK 8中被棄用的垃圾收集組合將在JDK 9中刪除。這之中包括不多使用的組合,如增量CMS、ParNew + SerialOld和DefNew + CMS,由於它們增長了垃圾收集器代碼庫的額外複雜度。
Java 9還將對import語句進行省略Java警告,以幫助大型代碼庫清除lint警告。在這些代碼庫中,對被棄用的功能,還會支持一段時間,並且若是是有目的地要使用一個被棄用的構造,那麼導入棄用的構造就不須要發出警告消息。
在啓動時經過多個JRE(mJRE)特性選擇JRE的功能也被棄用。這種功能不多被使用,由於這會使Java啓動器的實現變得更加複雜,而且在JDK 5中首次出現時,它從未被徹底地實現。
Oracle正在刪除JVM TI(工具接口)hprof(堆分析)代理,它已被JVM取代。jhat工具也被刪除了,它已經被高級的堆可視化工具和分析器淘汰了。