關於java中堆和棧的區別

來源:文萃谷 2.54W

當一個人開始學習Java或者其他編程語言的時候,會接觸到堆和棧,由於一開始沒有明確清晰的説明解釋,很多人會產生很多疑問,什麼是堆,什麼是棧,堆和棧有什麼區別?更糟糕的是,Java中存在棧這樣一個後進先出(Last In First Out)的順序的數據結構,這就是k。這種情況下,不免讓很多人更加費解前面的問題。事實上,堆和棧都是內存中的一部分,有着不同的作用,而且一個程序需要在這片區域上分配內存。眾所周知,所有的Java程序都運行在JVM虛擬機內部,我們這裏介紹的自然是JVM(虛擬)內存中的堆和棧。

關於java中堆和棧的區別

 區別

java中堆和棧的區別自然是面試中的常見問題,下面幾點就是其具體的區別

 各司其職

最主要的區別就是棧內存用來存儲局部變量和方法調用。

而堆內存用來存儲Java中的對象。無論是成員變量,局部變量,還是類變量,它們指向的對象都存儲在堆內存中。

獨有還是共享

棧內存歸屬於單個線程,每個線程都會有一個棧內存,其存儲的`變量只能在其所屬線程中可見,即棧內存可以理解成線程的私有內存。

而堆內存中的對象對所有線程可見。堆內存中的對象可以被所有線程訪問。

 異常錯誤

如果棧內存沒有可用的空間存儲方法調用和局部變量,JVM會拋出kOverFlowError。

而如果是堆內存沒有可用的空間存儲生成的對象,JVM會拋出fMemoryError。

 空間大小

棧的內存要遠遠小於堆內存,如果你使用遞歸的話,那麼你的棧很快就會充滿。如果遞歸沒有及時跳出,很可能發生StackOverFlowError問題。

你可以通過-Xss選項設置棧內存的大小。-Xms選項可以設置堆的開始時的大小,-Xmx選項可以設置堆的最大值。

這就是Java中堆和棧的區別。理解好這個問題的話,可以對你解決開發中的問題,分析堆內存和棧內存使用,甚至性能調優都有幫助。

查看默認值(Updated)

查看堆的默認值,使用下面的代碼,其中InitialHeapSize為最開始的堆的大小,MaxHeapSize為堆的最大值。

複製代碼 代碼如下:

13:17 $ java -XX:+PrintFlagsFinal -version | grep HeapSize

uintx ErgoHeapSizeLimit = 0 {product}

uintx HeapSizePerGCThread = 87241520 {product}

uintx InitialHeapSize := 134217728 {product}

uintx LargePageHeapSizeThreshold = 134217728 {product}

uintx MaxHeapSize := 2147483648 {product}

java version "1.8.0_25"

Java(TM) SE Runtime Environment (build 1.8.0_25-b17)

Java HotSpot(TM) 64-Bit Server VM (build 25.25-b02, mixed mode)

查看棧的默認值,其中ThreadStackSize為棧內存的大小。

複製代碼 代碼如下:

13:21 $ java -XX:+PrintFlagsFinal -version | grep ThreadStackSize

intx CompilerThreadStackSize = 0 {pd product}

intx ThreadStackSize = 1024 {pd product}

intx VMThreadStackSize = 1024 {pd product}

java version "1.8.0_25"

Java(TM) SE Runtime Environment (build 1.8.0_25-b17)

Java HotSpot(TM) 64-Bit Server VM (build 25.25-b02, mixed mode)

譯文信息

原汁原味的英文原文:http://javarevisited.blogsp

譯文在原文基礎上進行了修改,整理,刪減。如有興趣可以訪問原文。P.S.地址已被牆。

熱門標籤