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