Java多线程-程序运行堆栈分析
class文件內容
class文件包含JAVA程序執行的字節碼;數據嚴格按照格式緊湊排列在class文件中的二進制流,中間無任何分隔符;文件開頭有一個0xcafebabe(16進制)特殊的一個標志。
JVM運行時數據區
線程獨占:每個線程都會有它獨立的空間,隨線程生命周期而創建和銷毀
線程共享:所有線程能訪問這塊內存數據,隨虛擬機或者GC而創建和銷毀
方法區
JVM用來存儲加載的類信息、常量、靜態變量、編譯后的代碼等數據。
虛擬機規范中這是一個邏輯區劃。具體實現根據不同虛擬機來實現。
如:oracle的HotSpot在java7中方法區放在永久代,java8放在元數據空間,并且通過GC機制對這個區域進行管理
堆內存
堆內存還可以細分為:老年代、新生代(Eden、From Survivor、To Survivor)
JVM啟動時創建,存放對象的實例。垃圾回收器主要就是管理堆內存。
如果滿了,就會出現OutOfMemoryError。
虛擬機棧
虛擬機棧,每個線程都在這個空間有一個私有的空間。
線程棧由多個棧幀(Stack Frame)組成。
一個線程會執行一個或多個方法,一個方法對應一個棧幀。
棧幀內容包含:局部變量表、操作數棧、動態鏈接、方法返回地址、附件信息等。
棧內存默認最大是1M,超出則拋出StackOverflowError
本地方法棧
和虛擬機棧功能類似,虛擬機棧是為虛擬機執行JAVA方法而準備的,本地方法棧是為虛擬機使用Native本地方法而準備。
虛擬機規范沒有規定具體的實現,由不同的虛擬機廠商去實現。
HotSpot虛擬機中虛擬機棧和本地方法棧的實現方式一樣的。同樣,超出大小以后也會拋出StackOverflowError。
程序計數器
程序計數器(Program Counter Register)記錄當前線程執行字節碼的位置,存儲的是字節碼指令地址,如果執行Native方法,則計數器值為空。
每個線程都在這個空間有一個私有的空間,占用內存空間很少。
CPU同一時間,只會執行一條線程中的指令。JVM多線程會輪流切換并分配CPU執行時間的方式。為了線程切換后,需要通過程序計數器,來恢復正確的執行位置。
轉載于:https://www.cnblogs.com/loveyous/p/11407504.html
總結
以上是生活随笔為你收集整理的Java多线程-程序运行堆栈分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 改变 input[type=range
- 下一篇: Java多线程-线程状态