java線程池原理 如何準(zhǔn)確理解Java中的堆與棧?
如何準(zhǔn)確理解Java中的堆與棧?謝謝!Java運(yùn)行時數(shù)據(jù)區(qū)有Java虛擬機(jī)棧和本地方法棧,用于執(zhí)行方法;堆用于存儲對象實(shí)例和數(shù)組。Java虛擬機(jī)堆棧執(zhí)行每個Java方法時,將創(chuàng)建一個堆??蚣堋6褩?/p>
如何準(zhǔn)確理解Java中的堆與棧?
謝謝
!Java運(yùn)行時數(shù)據(jù)區(qū)有Java虛擬機(jī)棧和本地方法棧,用于執(zhí)行方法;堆用于存儲對象實(shí)例和數(shù)組。
Java虛擬機(jī)堆棧
執(zhí)行每個Java方法時,將創(chuàng)建一個堆棧框架。堆棧幀用于存儲局部變量列表、操作數(shù)堆棧、動態(tài)鏈表和方法出口等信息。每個Java方法從調(diào)用開始到執(zhí)行完成的過程,對應(yīng)于Java虛擬機(jī)棧中棧幀從棧入口到棧出口的過程。根據(jù)Java虛擬機(jī)規(guī)范,如果線程請求的深度大于虛擬機(jī)允許的深度,則拋出StackOverflowerError異常;如果虛擬機(jī)可以動態(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)存空間?;旧?,所有對象實(shí)例和數(shù)組都在這里分配內(nèi)存空間,這是所有線程共享的。在Java虛擬機(jī)規(guī)范中,堆可以位于物理上不連續(xù)的內(nèi)存空間中,只要它在邏輯上是連續(xù)的。當(dāng)堆中沒有足夠的內(nèi)存分配并且此時無法擴(kuò)展時,將拋出outofmemoryerror異常。
jvm:java代碼是如何運(yùn)行的?
一個java項目包含許多帶有“.”的源代碼文件。Java“后綴。除了直接在IDE中調(diào)試外,一般來說,代碼類型是jar包或war包,最后打包的jar包或war包被發(fā)送到在線服務(wù)器進(jìn)行部署。
部署的方法有很多,最基本的方法是通過Tomcat容器進(jìn)行部署,也可以通過Java命令手動運(yùn)行jar包中的代碼。
。
在Java代碼打包過程中,源代碼通常被編譯成一個字節(jié)碼文件,并帶有“?!邦悺焙缶Y。JVM只能識別和解釋字節(jié)碼文件類。
對于已編譯的類字節(jié)碼,您需要使用諸如Java-jar之類的命令來運(yùn)行已編寫的代碼;一旦使用Java命令,此時您將實(shí)際啟動JVM進(jìn)程。
JVM進(jìn)程將負(fù)責(zé)運(yùn)行這些類字節(jié)碼文件,這相當(dāng)于運(yùn)行我們編寫的代碼。
要運(yùn)行這些類字節(jié)碼文件中的代碼,JVM將使用類加載器將編譯后的類字節(jié)碼文件加載到JVM的內(nèi)存中
執(zhí)行加載到內(nèi)存中的類。當(dāng)JVM需要哪個類時,它將使用類加載器來加載相應(yīng)的類。