欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中堆和棧的區(qū)別詳解

 更新時(shí)間:2015年01月16日 09:56:33   投稿:junjie  
這篇文章主要介紹了Java中堆和棧的區(qū)別詳解,所有的Java程序都運(yùn)行在JVM虛擬機(jī)內(nèi)部,我們這里介紹的自然是JVM(虛擬)內(nèi)存中的堆和棧,需要的朋友可以參考下

當(dāng)一個(gè)人開(kāi)始學(xué)習(xí)Java或者其他編程語(yǔ)言的時(shí)候,會(huì)接觸到堆和棧,由于一開(kāi)始沒(méi)有明確清晰的說(shuō)明解釋?zhuān)芏嗳藭?huì)產(chǎn)生很多疑問(wèn),什么是堆,什么是棧,堆和棧有什么區(qū)別?更糟糕的是,Java中存在棧這樣一個(gè)后進(jìn)先出(Last In First Out)的順序的數(shù)據(jù)結(jié)構(gòu),這就是java.util.Stack。這種情況下,不免讓很多人更加費(fèi)解前面的問(wèn)題。事實(shí)上,堆和棧都是內(nèi)存中的一部分,有著不同的作用,而且一個(gè)程序需要在這片區(qū)域上分配內(nèi)存。眾所周知,所有的Java程序都運(yùn)行在JVM虛擬機(jī)內(nèi)部,我們這里介紹的自然是JVM(虛擬)內(nèi)存中的堆和棧。

區(qū)別

java中堆和棧的區(qū)別自然是面試中的常見(jiàn)問(wèn)題,下面幾點(diǎn)就是其具體的區(qū)別

各司其職

最主要的區(qū)別就是棧內(nèi)存用來(lái)存儲(chǔ)局部變量和方法調(diào)用。
而堆內(nèi)存用來(lái)存儲(chǔ)Java中的對(duì)象。無(wú)論是成員變量,局部變量,還是類(lèi)變量,它們指向的對(duì)象都存儲(chǔ)在堆內(nèi)存中。

獨(dú)有還是共享

棧內(nèi)存歸屬于單個(gè)線(xiàn)程,每個(gè)線(xiàn)程都會(huì)有一個(gè)棧內(nèi)存,其存儲(chǔ)的變量只能在其所屬線(xiàn)程中可見(jiàn),即棧內(nèi)存可以理解成線(xiàn)程的私有內(nèi)存。
而堆內(nèi)存中的對(duì)象對(duì)所有線(xiàn)程可見(jiàn)。堆內(nèi)存中的對(duì)象可以被所有線(xiàn)程訪(fǎng)問(wèn)。

異常錯(cuò)誤

如果棧內(nèi)存沒(méi)有可用的空間存儲(chǔ)方法調(diào)用和局部變量,JVM會(huì)拋出java.lang.StackOverFlowError。
而如果是堆內(nèi)存沒(méi)有可用的空間存儲(chǔ)生成的對(duì)象,JVM會(huì)拋出java.lang.OutOfMemoryError。

空間大小

棧的內(nèi)存要遠(yuǎn)遠(yuǎn)小于堆內(nèi)存,如果你使用遞歸的話(huà),那么你的棧很快就會(huì)充滿(mǎn)。如果遞歸沒(méi)有及時(shí)跳出,很可能發(fā)生StackOverFlowError問(wèn)題。
你可以通過(guò)-Xss選項(xiàng)設(shè)置棧內(nèi)存的大小。-Xms選項(xiàng)可以設(shè)置堆的開(kāi)始時(shí)的大小,-Xmx選項(xiàng)可以設(shè)置堆的最大值。

這就是Java中堆和棧的區(qū)別。理解好這個(gè)問(wèn)題的話(huà),可以對(duì)你解決開(kāi)發(fā)中的問(wèn)題,分析堆內(nèi)存和棧內(nèi)存使用,甚至性能調(diào)優(yōu)都有幫助。

查看默認(rèn)值(Updated)

查看堆的默認(rèn)值,使用下面的代碼,其中InitialHeapSize為最開(kāi)始的堆的大小,MaxHeapSize為堆的最大值。

復(fù)制代碼 代碼如下:

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)

查看棧的默認(rèn)值,其中ThreadStackSize為棧內(nèi)存的大小。

復(fù)制代碼 代碼如下:

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.blogspot.com.au/2013/01/difference-between-stack-and-heap-java.html.

譯文在原文基礎(chǔ)上進(jìn)行了修改,整理,刪減。如有興趣可以訪(fǎng)問(wèn)原文。P.S.地址已被墻。

相關(guān)文章

最新評(píng)論