本文會根據針對即將發布的Java 9新特性做同步更新(最後更新:9/9/2014)
加快OpenJDK的開發速度: 繼2014年3月份發布了Java 8之後,我們進入下一個兩年的發布週期. Java 9預計在2016年發布,並且已經公佈了JEP(JDK改進提議)中的前期列表.同時,我們已經把一些新特性整理到了JSR(Java規範請求),還有提出了一些希望包括在新版本中的其他特性.
這些重要的特性都包括在Jigsaw專案中。顯著的性能改善和期待已久的API包括:進程API更新,JSON將成為java.util的一部分,貨幣處理API.對於想處在技術最前沿的你,可從這裡獲得Java 9的初期版本.
本文將根據Java 9的新特性做持續更新。請關注!
1. Jigsaw 專案;模組化原始碼
Jigsaw專案是為了模組化Java程式碼、將JRE分成可相互協作的元件,這也是Java 9 眾多特色種的一個。 JEP是邁向Jigsaw四步驟中的第一步,它不會改變JRE和JDK的真實結構。 JEP是為了模組化JDK原始碼,讓編譯系統能夠模組編譯並在建置時檢查模組邊界。這個項目原本是隨Java 8發布的,但由於推遲,所以將把它加到Java 9.
一旦它完成,它可能允許根據一個項目需求自定義組件從而減少rt.jar的大小。在JDK 7 和JDK 8的rt.jar包中有大約20,000個類,但有很多類在一些特定的環境裡面並沒有被用到(即使在Java 8的緊湊分佈特性中已經包含了一部分解決方法也存在著類別冗餘)。這麼做是為了能讓Java能夠輕鬆應用到小型運算設備(例如網路設備)中,提高它的安全性和效能,同時也能讓開發者更容易建置和維護這些類別庫。
更多JEP 201內容
2.簡化流程API
截止到目前,Java控制與管理系統流程的能力是有限的。舉個例子,現在為了簡單取得你程式的進程PID,你要嘛呼叫本地程式要嘛要自己使用一些變通方案。更多的是,每個(系統)平台需要有一個不同實作來確保你能獲得正確的結果。
期望程式碼能取得Linux PIDS,現在是如下方式:
public static void main(String[] args) throws Exception { Process proc = Runtime.getRuntime().exec(new String[]{ "/bin/sh", "-c", "echo $PPID" }); if (proc.waitFor() == 0) { InputStream in = proc.getInputStream(); int available = in.available(); byte[] outputBytes = new byte[available]; in.read(outputBytes); String pid = new String(outputBytes); System.out.println("Your pid is " + pid); } }
在Java 9中,可以變換成如下方式(支援所有的作業系統):
System.out.println("Your pid is " + Process.getCurrentPid());
作業系統將會擴展Java與這次作業系統的交互能力:新增一些新的直接明了的方法去處理PIDs,進程名字和狀態以及枚舉多個JVM和進程以及更多事情。
3. 輕量級 JSON API
目前有多種處理JSON的Java工具,但JSON API 獨到之處在於JSON API將作為Java語言的一部分,輕量級並且運用Java 8的新特性。它將放在java.util套件裡一起發布(但在JSR 353裡面的JSON是用第三方套件或其他的方法處理的).
**程式碼範例稍後列出!
4. 錢和貨幣的API
在Java 8引進了日期和時間的API之後, Java 9引入了新的貨幣API, 用以表示貨幣, 支持幣種之間的轉換和各種複雜運算.關於這個專案的具體情況, 請訪問https://github.com/JavaMoney,裡面已經給出了使用說明和示例, 以下是幾個重要的例子:
//新的类型: Money & FastMoney Money amt1 = Money.of(10.1234556123456789, "USD"); // Money is a BigDecimal FastMoney amt2 = FastMoney.of(123456789, "USD"); // FastMoney is up to 5 decimal places Money total = amt1.add(amt2);
// 钱表达成各国货币的方法: MonetaryAmountFormat germanFormat = MonetaryFormats.getAmountFormat( Locale.GERMANY); System.out.println(germanFormat.format(monetaryAmount)); // 1.202,12 USD
5. 改善鎖爭用機制
鎖爭用是限制許多Java多執行緒應用效能的瓶頸. 新的機制在改善Java物件監視器的效能方面已經得到了多種基準(benchmark)的驗證, 其中包括Volano. 測試中通訊伺服器開放了大量的進程來連接客戶端, 其中有很多連接都申請同一個資源, 以此模擬重負荷日常應用.
透過諸如此類的壓力測試我們可以估算JVM的極限吞吐量(每秒的消息數量). JEP在22種不同的測試中都得到了出色的成績, 新的機制如果能在Java 9中得到應用的話,應用程式的效能將會大大提升.
6. 程式碼分段快取
Java 9的另一個效能提升來自於JIT(Just-in-time)編譯器. 當某段程式碼被大量重複執行的時候,虛擬機會把這段程式碼編譯成機器碼(native code)並儲存在程式碼快取裡面, 進而透過存取快取中不同分段的程式碼來提升編譯器的效率.
和原來的單一快取區域不同的是,新的程式碼快取根據程式碼本身的生命週期而分為三種:
- 永駐程式碼(JVM 內建/ 非方法程式碼)
-短期程式碼(僅在某些條件下適用的配置性(profiled)程式碼)
- 長期代碼(非配置性代碼)
緩存分段會在各個方面提升程序的性能, 比如做垃圾回收掃描的時候可以直接跳過非方法代碼(永駐代碼), 從而提升效率.
7. 智能Java編譯, 第二階段
智能Java編譯工具sjavac的第一階段開始於JEP 139這個專案, 用於在多核心處理器上提升JDK的編譯速度. 現在這個專案已經進入第二階段。沒正式發布, 但是已經進入了最終審查階段, 預計可以在Java 9發布之前審查完畢. JEP 110將會重新定義並實現一個全新的Java HTTP客戶端, 用來取代現在的HttpURLConnection, 同時也會實現HTTP 2.0和網路介面(原文websockets). 它現在還沒被JEP正式認可但我們希望在Java 9中包含這一項目的內容.
官方的HTTP 2.0 RFC(Request for Comments, 官方技術討論/會議記錄等等的一系列文件記錄)預訂於2015年2月發布, 它是基於Google發布的SPDY(Speedy, 快速的)協議. 基於SPDY協議的網絡相對於基於HTTP 1.1協議的網絡有11.81%到47.7%之間的顯著提速, 現在已經有瀏覽器實現了這個協議.
9. Kulla計劃: Java的REPL實現
這個取名為Kulla的項目最近宣布將於2015年4月整合測試, 雖然已經不太有希望能趕上Java 9的發布, 但如果進度快的話或許剛好能趕上. 現在Java並沒有來自官方的REPL(Read-Eval-Print-Loop)方式, 也就是說現在如果你想要跑幾行Java程式碼做一個快速的測試, 你仍然需要把這幾行程式碼封裝在專案或方法裡面. 雖然在一些流行的IDE裡面有Java REPL工具, 但它們並沒有官方支持, 而Kulla專案或許就能成為Java官方發布的REPL解決方案.
更多關於Kulla計劃的內容
這些新功能出自何處?
JEP和JSR 下面並不是對中生有何 介紹一下
JEP和JSR 以下對中生有何特定技術內容, 例如安全, 網路, Swing, HotSpot, 有共同興趣的組織和個人
專案- 編寫程式碼, 文件以及其他工作, 至少由一個小組贊助和支持, 例如最近的Lambda計劃, Jigsaw計劃和Sumatra計劃.
JDK改進提案(JEP) - 每當需要有新的嘗試的時候, JEP可以在JCP(Java Community Process)之前或者同時提出非正式的規範(specification). 被正是認可的JEP正式寫入JDK的發展路線圖並分配版本號.
Java規範提案(JSR) - 新特性的規範出現在這一個階段, 可以來自於小組/ 項目, JEP, JCP成員或者Java社區(community)成員的提案. 每個Java版本都由對應的JSR支援, Java 9暫時還沒有.