使用Java編程時,考慮到終寫成程序的執行效率,可能在選擇直接使用Java堆new對象,或是直接分配本地內存之間很難做出決定?;浨?strong>武漢Java培訓來對比下Java堆與本地內存。
使用Java的一個好處就是你可以不用親自來管理內存的分配和釋放。當你用new關鍵字來實例化一個對象時,它所需的內存會自動的在Java堆中分配。堆會被垃圾回收器進行管理,并且它會在對象超出作用域時進行內存回收。但是在JVM中有一個‘后門’可以讓你訪問不在堆中的本地內存(native memory)。
使用Unsafe來分配和回收內存
sun.misc.Unsafe可以讓你在Java中分配和回收本地內存,就像C語言中的malloc和free。通過它分配的內存不在Java堆中,并且不受垃圾回收器的管理,因此在它被使用完的時候你需要自己來負責釋放和回收。
跨越JVM的屏障來讀本地內存大約會比直接讀Java堆中的內存慢10倍,而對于寫操作會慢大約2倍。但是需要注意的是,由于每一個SomeMemoryObject對象所管理的本地內存空間都是獨立的,因此讀寫操作都不是連續的。那么粵嵌武漢Java培訓接下來就來對比下讀寫連續的內存空間的性能。
訪問一大塊的連續內存空間
在做連續訪問的時候,Java堆內存通常都比本地內存要快。對于隨機地址訪問,堆內存僅僅比本地內存慢一點點,并且是針對大塊連續數據的時候,而且沒有慢很多。
的結論
在Java中使用本地內存有它的意義,比如當你要操作大塊的數據時(>2G)并且不想使用垃圾回收器(GC)的時候。從延遲的角度來說,直接訪問本地內存不會比訪問Java堆快。這個結論其實是有道理的,因為跨越JVM屏障肯定是有開銷的。這樣的結論對使用本地還是堆的ByteBuffer同樣適用。使用本地ByteBuffer的速度提升不在于訪問這些內存,而是它可以直接與操作系統提供的本地IO進行操作。
粵嵌武漢Java培訓認為,事實上使用Java寫的程序,經過編譯器編譯打亂后很可能已經不是自己所想象的樣子了,畢竟Java是面向對象的語言,所以更多的時候還不如怎么寫得快就怎么寫,畢竟編譯器在很多時候都不太聰明,我們自以為寫的很直接的程序也有可能編譯成亂糟糟的復雜的機器語言。