Java Valhalla Project項目介紹
前言:
在本文中,我們將介紹Valhalla項目——它的歷史原因、當前的開發狀態,以及它發佈後為日常Java開發人員帶來瞭什麼。
Valhalla項目的動機和原因
Oracle的Java語言架構師Brian Goetz在一次演講中說,Valhalla項目的主要動機之一是希望使Java語言和運行時適應現代硬件。當Java語言誕生時(大約25年前撰寫本文時),獲取內存和算術運算的成本大致相同。
如今,這種情況已經發生瞭變化,內存提取操作的成本是算術操作的200到1000倍。就語言設計而言,這意味著導致指針提取的間接操作會對整體性能產生不利影響。
由於應用程序中的大多數Java數據結構都是對象,因此我們可以將Java視為指針密集型語言(盡管我們通常不會直接看到或操作它們)。這種基於指針的對象實現用於啟用對象標識,對象標識本身用於語言特性,如多態性、可變性和鎖定。默認情況下,這些特性適用於每個對象,無論它們是否真的需要。
遵循導致指針的標識鏈和導致間接的指針鏈,間接存在性能缺陷,邏輯上的結論是刪除那些不需要它們的數據結構。這就是值類型value types發揮作用的地方。
Value Types 值類型
值類型的概念是表示純數據聚合。這會刪除常規對象的功能。因此,我們有純數據,沒有身份。當然,這意味著我們也失去瞭使用對象標識可以實現的功能。因此,平等比較隻能基於狀態進行。因此,我們不能使用表示多態性,也不能使用不可變或不可為空的對象。
由於我們不再有對象標識,我們可以放棄指針,改變值類型的一般內存佈局,而不是對象。讓我們來比較一下類點和相應的值類型點之間的內存佈局。
常規Point類的代碼和相應的內存佈局為:
final class Point { final int x; final int y; }
另一方面,值類型Point的代碼和相應的內存佈局將是:
value class Point { int x; int y }
這允許JVM將值類型展平為數組和對象,以及其他值類型。
在下圖中,我們展示瞭在數組中使用Point類時間接的負面影響:
另一方面,這裡我們看到值類型Point[]
的相應內存結構:
它還使JVM能夠在棧上傳遞值類型,而不必在堆上分配它們。最後,這意味著我們得到的數據聚合具有類似於Java原語的運行時行為,如int
或float
。
但與原語不同,值類型可以有方法和字段。我們還可以實現接口並將其用作泛型類型。
因此,我們可以從兩個不同的角度來看值類型:
- 更快的對象
- 用戶定義原語
作為額外的錦上添花,我們可以使用值類型作為泛型類型,而無需裝箱。這直接將我們引向瞭另一個大型項目Valhalla的特性:專用泛型。
Specialized Generics 專用泛型
當我們想對語言原語進行泛化時,我們目前使用裝箱類型,例如整數表示Integer
或浮點表示Float
。這種裝箱創建瞭一個額外的間接層,從而首先破壞瞭使用原語提高性能的目的。
因此,我們在現有的框架和庫中看到瞭許多針對基元類型的專門化,如IntStream<T>
或ToIntFunction<T>
。這樣做是為瞭保持使用原語的性能提高。
因此,專門化泛型是為瞭消除這些“黑客”的需求。相反,Java語言努力為基本上所有東西啟用泛型類型:對象引用、原語、值類型,甚至可能是void
。
結論
我們初步瞭解瞭Valhalla項目將給Java語言帶來的變化。其中兩個主要目標是提高性能和減少泄漏的抽象。
性能增強通過展平對象圖和移除間接來解決。這將導致更高效的內存佈局和更少的分配和垃圾回收。
當用作泛型類型時,原語和對象具有更相似的行為,這是更好的抽象。
到此這篇關於Java Valhalla Project項目介紹的文章就介紹到這瞭,更多相關Java Valhalla Project內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Java即將引入新對象類型來解決內存使用問題
- Java泛型的類型擦除示例詳解
- Java mutable對象和immutable對象的區別說明
- Java基礎概述面試題復習
- java兩個integer數據判斷相等用==還是equals