java棧的使用 如何準(zhǔn)確理解Java中的堆與棧?
如何準(zhǔn)確理解Java中的堆與棧?謝謝!Java運(yùn)行時(shí)數(shù)據(jù)區(qū)有Java虛擬機(jī)棧和本地方法棧,用于執(zhí)行方法;堆用于存儲(chǔ)對(duì)象實(shí)例和數(shù)組。Java虛擬機(jī)堆棧執(zhí)行每個(gè)Java方法時(shí),將創(chuàng)建一個(gè)堆??蚣?。堆棧幀用
如何準(zhǔn)確理解Java中的堆與棧?
謝謝
!Java運(yùn)行時(shí)數(shù)據(jù)區(qū)有Java虛擬機(jī)棧和本地方法棧,用于執(zhí)行方法;堆用于存儲(chǔ)對(duì)象實(shí)例和數(shù)組。
Java虛擬機(jī)堆棧
執(zhí)行每個(gè)Java方法時(shí),將創(chuàng)建一個(gè)堆??蚣堋6褩糜诖鎯?chǔ)局部變量列表、操作數(shù)堆棧、動(dòng)態(tài)鏈表和方法出口等信息。每個(gè)Java方法從調(diào)用開始到執(zhí)行完成的過程,對(duì)應(yīng)于Java虛擬機(jī)棧中棧幀從棧入口到棧出口的過程。根據(jù)Java虛擬機(jī)規(guī)范,如果線程請(qǐng)求的深度大于虛擬機(jī)允許的深度,則拋出StackOverflowerError異常;如果虛擬機(jī)可以動(dòng)態(tài)擴(kuò)展,但擴(kuò)展過程中內(nèi)存不足,則拋出outofmemoryerror異常。Java虛擬機(jī)棧的生命周期遵循線程,是線程的私有生命周期。
Local method stack
Java虛擬機(jī)堆棧用于執(zhí)行Java方法,而本地方法堆棧用于執(zhí)行本地方法。它的功能類似于Java虛擬機(jī)堆棧,還拋出StackOverflowerError異常和outofmemoryerror異常。本地方法堆棧的生存期也是線程跟隨和線程私有的。
Heap
堆是Java虛擬機(jī)中最大的內(nèi)存空間?;旧希袑?duì)象實(shí)例和數(shù)組都在這里分配內(nèi)存空間,這是所有線程共享的。在Java虛擬機(jī)規(guī)范中,堆可以位于物理上不連續(xù)的內(nèi)存空間中,只要它在邏輯上是連續(xù)的。當(dāng)堆中沒有足夠的內(nèi)存分配并且此時(shí)無法擴(kuò)展時(shí),將拋出outofmemoryerror異常。
關(guān)于數(shù)據(jù)結(jié)構(gòu)的,為什么棧空top是-1,top=0是指向棧頂下一個(gè)元素,在共享?xiàng)V幸惶?hào)棧怎么為空?
函數(shù)中定義的一些基本類型變量和對(duì)象引用變量分配在函數(shù)的堆棧內(nèi)存中。當(dāng)在代碼塊中定義變量時(shí),Java在堆棧中為變量分配內(nèi)存空間。當(dāng)超過變量的作用域時(shí),Java會(huì)自動(dòng)釋放為變量分配的內(nèi)存空間,該內(nèi)存空間可以立即用于其他用途。堆內(nèi)存用于存儲(chǔ)由new創(chuàng)建的對(duì)象和數(shù)組。堆中分配的內(nèi)存由Java虛擬機(jī)自動(dòng)垃圾收集器管理。在堆中生成數(shù)組或?qū)ο蠛?,還可以在堆棧中定義特殊變量。此變量的值等于堆內(nèi)存中數(shù)組或?qū)ο蟮牡谝粋€(gè)地址。堆棧中的這個(gè)特殊變量成為數(shù)組或?qū)ο蟮囊米兞?,然后可以使用堆棧?nèi)存中的引用變量訪問程序堆中的數(shù)組或?qū)ο蟆R米兞康刃в跀?shù)組或?qū)ο蟮膭e名或代碼名。引用變量是公共變量。當(dāng)它被定義時(shí),內(nèi)存被分配到堆棧中,引用變量被釋放到程序范圍之外。數(shù)組和對(duì)象本身在堆中分配。即使程序在使用new語句生成數(shù)組和對(duì)象的代碼塊之外運(yùn)行,數(shù)組和對(duì)象本身占用的堆內(nèi)存也不會(huì)被釋放。當(dāng)數(shù)組和對(duì)象沒有引用指向它的變量時(shí),它們就變成了垃圾并且不能再使用,但是它們?nèi)匀粫?huì)在垃圾收集器釋放的不確定時(shí)間內(nèi)占用內(nèi)存。這也是Java占用更多內(nèi)存的主要原因。這些事情都是在虛擬機(jī)內(nèi)完成的,我們不需要操作,你知道怎么回事。