java創(chuàng)建一個(gè)棧 如何按現(xiàn)棧底再棧頂?shù)捻樞虼蛴∫粋€(gè)棧里的所有的元素 (java)?
如何按現(xiàn)棧底再棧頂?shù)捻樞虼蛴∫粋€(gè)棧里的所有的元素 (java)?如果堆棧是由您編寫的,您可以按所需順序打印每個(gè)元素。如果堆棧的類是由其他人編寫的,并且其他人為您提供了push、pop方法,那么估計(jì)只有
如何按現(xiàn)棧底再棧頂?shù)捻樞虼蛴∫粋€(gè)棧里的所有的元素 (java)?
如果堆棧是由您編寫的,您可以按所需順序打印每個(gè)元素。如果堆棧的類是由其他人編寫的,并且其他人為您提供了push、pop方法,那么估計(jì)只有所有的pop方法會(huì)從這個(gè)方法中出來(lái)= = = = = = = = = = = = = = = = = = = = = = = = =? 好吧,我不認(rèn)為有一個(gè)好的方法可以從外部完成,因?yàn)槎褩V挥羞@兩個(gè)操作,除非它也像Java中的堆棧一樣提供整個(gè)線性表的功能。但是如果需要向后遍歷,我認(rèn)為使用堆棧作為數(shù)據(jù)結(jié)構(gòu)是不合適的。您使用什么樣的數(shù)據(jù)結(jié)構(gòu)取決于您的需求。例如,你所做的是堆棧的概念,你真的只需要走出去進(jìn)入堆棧,然后你只需要堆棧。堆棧:每當(dāng)啟動(dòng)一個(gè)新線程時(shí),Java虛擬機(jī)都會(huì)為其分配一個(gè)Java堆棧。JVM將只在Java堆棧上執(zhí)行兩個(gè)操作:堆棧按下或以堆棧幀為單位退出堆棧。每個(gè)線程都包含一個(gè)堆棧區(qū)域,其中只存儲(chǔ)基本數(shù)據(jù)類型的對(duì)象和自定義對(duì)象(而不是對(duì)象)的引用,對(duì)象存儲(chǔ)在堆棧區(qū)域中。
2. 堆:存儲(chǔ)所有對(duì)象,每個(gè)對(duì)象都包含相應(yīng)的類信息——類的目的是獲取操作指令。JVM中的所有線程只共享一個(gè)堆。堆不存儲(chǔ)基本類型和對(duì)象引用,只存儲(chǔ)對(duì)象本身。
jvm堆和棧的區(qū)別?
謝謝
!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í)行完成的過(guò)程,對(duì)應(yīng)于Java虛擬機(jī)棧中棧幀從棧入口到棧出口的過(guò)程。根據(jù)Java虛擬機(jī)規(guī)范,如果線程請(qǐng)求的深度大于虛擬機(jī)允許的深度,則拋出StackOverflowerError異常;如果虛擬機(jī)可以動(dòng)態(tài)擴(kuò)展,但擴(kuò)展過(guò)程中內(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)堆中沒(méi)有足夠的內(nèi)存分配并且此時(shí)無(wú)法擴(kuò)展時(shí),將拋出outofmemoryerror異常。