java JVM虚拟机
JVM垃圾處理方法(標記清除、復制、標記整理)
1、標記清除
標記階段:先通過根節點,標記所有從根節點開始的對象,未被標記的為垃圾對象。
清除階段:清除所有未被標記的對象。
2、復制算法
將原有的空間分為兩塊,每次只使用其中的一塊,將正在使用的內存中的存活的對象復制到未使用的內存塊中,
然后清除正在使用的內存塊中的所有對象。
3、標記----整理
1.標記階段:先通過根節點,標記所有從根節點開始的可達對象,為被標記的為垃圾對象
2、整理階段:將所有的存活對象壓縮到內存的一段,之后清理邊界所有空間
? 三種算法的比較
1、效率:復制算法 > 標記/整理算法 > 標記/清除算法(此處的效率只是簡單的對比時間復雜度,實際情況不一定如 此)。
2、內存整齊度:復制算法=標記/整理算法>標記/清除算法。?
3、內存利用率:標記/整理算法=標記/清除算法>復制算法
JVM如何GC,新生代,老年代,持久代都儲存那些東西,以及各個區的作用?
1、新生代
在方法中去new一個對象,那這個方法調用完畢后,對象就會被回收,這個就是一個典型的新生代對象。
2、老年代
在經歷了N次垃圾回收后仍舊存活的對象就會被放到老年代中。而且大對象直接直接進入老年代
當Survivor空間不夠用時,需要依賴于老年代進行分配擔保,所以大對象直接進入老年代
3、永久代
即方法區
GC用的引用可達性分析算法中,那些對象可作為GC Roots 對象?
1、java虛擬機棧中的對象
2、方法區中的靜態成員
3、方法區中的常量引用對象
4、本地方法區中的JNI(Native方法)引用對象。
什么時候進行MinGC 、FullGC
1、MinGC
1》新生代中的垃圾收集動作,采用的是復制算法
2》對于較大的對象,在Minor GC的時候可以直接進入老年代
?
2、FullGC
1》Full GC 是發生在老年代的垃圾收集動作,采用的是標記--清除/整理算法
2》由于老年代的對象幾乎都是在Survivor去熬過來的,不會那么容易死掉,因此Full GC發生的次數不會有Minor GC
那么頻繁,并且Time(Full Gc)>Time(Minor Gc)
Java虛擬機內存的劃分,每個區域的功能
? 程序計數器(線程私有)
○ 線程創建時創建,執行本地方法時其值為undefined。
? 虛擬機棧(線程私有)
○ (棧內存)為虛擬機執行java方法服務:方法被調用時創建棧幀-->局部變量表->局部變量、對象引用 ○ 如果線程請求的棧深度超出了虛擬機允 許 的深度,就會出現StackOverFlowError。-Xss規定了棧的大空間
○ 虛擬機棧可以動態擴展,如果擴展到無法申請到足夠的內存,會出現OOM
? 本地方法棧(線程私有)
○ java虛擬機棧是為虛擬機執行java方法服務的,而本地方法棧則為虛擬機執使用到的Native方法服務。
○ Java虛擬機沒有對本地方法棧的使用和數據結構做強制規定。Sun HotSpot把Java虛擬機棧和本地方法棧合二為一
○ 會拋出StackOverFlowError和OutOfMemoryError
? Java堆
○ 被所有線程共享,在Java虛擬機啟動時創建,幾乎所有的對象實例都存放到堆中
○ GC的管理的主要區域
○ 物理不連續,邏輯上連續,并可以動態擴展,無法擴展時拋出OutOfMemoryError
? 方法區
○ 用于存儲已被虛擬機加載的類信息、常量、靜態變量、即使編譯器編譯后的代碼的數據
○ Sun HotSpot 虛擬機把方法區叫做永久待(Permanent Generation)
? 運行時常量池
○ 受到方法區的限制,拋出OutOfMemoryError?
JVM線程死鎖,你該如何判斷是因為什么?如果用VisualVM,dump線程信息出來,會有哪些信息
? 常常需要在隔兩分鐘后再次收集一次thread dump,如果得到的輸出相同,仍然是大量thread都在等待給同一個 地址上鎖,那么肯定是死鎖了。
?
轉載于:https://www.cnblogs.com/XiDaPuBen/p/8872240.html
總結
以上是生活随笔為你收集整理的java JVM虚拟机的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 关于图片裁剪
- 下一篇: 面试题目4:二维数组中的查找