日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java 垃圾回收机制,你知多少??

發布時間:2025/3/19 java 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java 垃圾回收机制,你知多少?? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

摘要: 垃圾回收機制是守護線程的最佳示例,因為它始終在后臺運行。

本文分享自華為云社區《 一文帶你了解Java 中的垃圾回收機制 》,作者:海擁。

介紹
在 C/C++ 中,程序員負責對象的創建和銷毀。通常程序員會忽略無用對象的銷毀。由于這種疏忽,在某些時候,為了創建新對象,可能沒有足夠的內存可用,整個程序將異常終止,導致 OutOfMemoryErrors 。
但是在 Java 中,程序員不需要關心所有不再使用的對象。垃圾回收機制自動銷毀這些對象。
垃圾回收機制是守護線程的最佳示例,因為它始終在后臺運行。
垃圾回收機制的主要目標是通過銷毀 無法訪問的對象 來釋放堆內存。
重要條款:
無法訪問的對象: 如果一個對象不包含對它的任何引用,則稱其為無法訪問的對象。另請注意,屬于隔離島的對象也無法訪問。

Integer i = new Integer(4);
// 新的 Integer 對象可通過 ‘i’ 中的引用訪問
i = null;
// Integer 對象不再可用。

垃圾回收的資格: 如果對象無法訪問,則稱該對象有資格進行 GC(垃圾回收)。在上圖中,在 i = null 之后; 堆區域中的整數對象 4 有資格進行垃圾回收。
使對象符合 GC 條件的方法
即使程序員不負責銷毀無用的對象,但如果不再需要,強烈建議使對象不可訪問(因此有資格進行 GC)。
通常有四種不同的方法可以使對象適合垃圾回收。
取消引用變量
重新分配引用變量
在方法內部創建的對象
隔離島
以上所有帶有示例的方法都在單獨的文章中討論:如何使對象符合垃圾收集條件

請求JVM運行垃圾收集器的方式
一旦我們使對象符合垃圾收集條件,垃圾收集器可能不會立即銷毀它。每當 JVM 運行垃圾收集器程序時,只會銷毀對象。但是當JVM運行Garbage Collector時,我們無法預料。
我們還可以請求 JVM 運行垃圾收集器。有兩種方法可以做到:
使用 System.gc() 方法: 系統類包含靜態方法 gc() 用于請求 JVM 運行垃圾收集器。
使用 Runtime.getRuntime().gc() 方法: 運行時類允許應用程序與運行應用程序的 JVM 交互。因此,通過使用其 gc() 方法,我們可以請求 JVM 運行垃圾收集器。

// 演示請求 JVM 運行垃圾收集器的 Java 程序 public class Test {public static void main(String[] args) throws InterruptedException{Test t1 = new Test();Test t2 = new Test();// 取消引用變量t1 = null;// 請求 JVM 來運行垃圾收集器System.gc();// 取消引用變量t2 = null;// 請求 JVM 來運行垃圾收集器Runtime.getRuntime().gc();}@Override// 在垃圾回收之前,在對象上調用一次 finalize 方法protected void finalize() throws Throwable{System.out.println("垃圾收集器調用");System.out.println("對象垃圾收集:" + this);} }

輸出:

垃圾收集器調用
對象垃圾收集:haiyong.Test@7ad74083
垃圾收集器調用
對象垃圾收集:haiyong.Test@7410a1a9

筆記 :
不能保證以上兩種方法中的任何一種都一定會運行垃圾收集器。
調用 System.gc() 等效于調用: Runtime.getRuntime().gc()
定稿
就在銷毀對象之前,垃圾收集器調用對象的 finalize() 方法來執行清理活動。一旦 finalize() 方法完成,垃圾收集器就會銷毀該對象。
finalize() 方法存在于具有以下原型的Object 類中。

protected void finalize() throws Throwable

根據我們的要求,我們可以覆蓋 finalize() 方法來執行我們的清理活動,例如關閉數據庫連接。

筆記 :
垃圾收集器而不是JVM調用的 finalize() 方法。雖然垃圾收集器是JVM的模塊之一。
對象類 finalize() 方法有空實現,因此建議覆蓋 finalize() 方法來處理系統資源或執行其他清理。
對于任何給定的對象, finalize() 方法永遠不會被多次調用。
如果 finalize() 方法拋出未捕獲的異常,則忽略該異常并終止該對象的終結。
有關 finalize() 方法的示例,請參閱Java 程序的輸出第十套之垃圾收集

讓我們舉一個真實的例子,在那里我們使用垃圾收集器的概念。
假設你去字節跳動實習,他們告訴你寫一個程序,計算在公司工作的員工人數(不包括實習生)。要制作這個程序,你必須使用垃圾收集器的概念。

這是您在公司獲得的實際任務:-

問: 編寫一個程序來創建一個名為 Employee 的類,該類具有以下數據成員。

1.一個ID,用于存儲分配給每個員工的唯一ID。

2.員工姓名。

3.員工年齡。

另外,提供以下方法-

用于初始化名稱和年齡的參數化構造函數。ID 應在此構造函數中初始化。
顯示 ID、姓名和年齡的方法 show()。
顯示下一個員工的 ID 的方法 showNextId()。
現在對垃圾回收機制不了解的初學者可能會這樣編寫代碼:

//計算在公司工作的員工人數的程序class Employee {private int ID;private String name;private int age;private static int nextId=1;//它是靜態的,因為它在所有對象之間保持通用并由所有對象共享public Employee(String name,int age){this.name = name;this.age = age;this.ID = nextId++;}public void show(){System.out.println("Id="+ID+"\nName="+name+"\nAge="+age);}public void showNextId(){System.out.println("Next employee id will be="+nextId);} } class UseEmployee {public static void main(String []args){Employee E=new Employee("GFG1",33);Employee F=new Employee("GFG2",45);Employee G=new Employee("GFG3",25);E.show();F.show();G.show();E.showNextId();F.showNextId();G.showNextId();{ //這是保留所有實習生的子塊。Employee X=new Employee("GFG4",23); Employee Y=new Employee("GFG5",21);X.show();Y.show();X.showNextId();Y.showNextId();}//這個大括號之后,X 和 Y 將被移除。因此現在它應該顯示 nextId 為 4。E.showNextId();//這一行的輸出應該是 4,但它會給出 6 作為輸出。} }

現在獲得正確的輸出:
現在垃圾收集器(gc)將看到 2 個空閑的對象?,F在遞減 nextId,gc(garbage collector) 只會在我們的程序員在我們的類中覆蓋它時調用方法 finalize() 。如前所述,我們必須請求 gc(garbage collector),為此,我們必須在關閉子塊的大括號之前編寫以下 3 個步驟。

將引用設置為 null(即 X = Y = null;)
調用,System.gc();
調用,System.runFinalization();
現在計算員工人數的正確代碼(不包括實習生)

// 計算不包括實習生的員工人數的正確代碼 class Employee {private int ID;private String name;private int age;private static int nextId=1;//它是靜態的,因為它在所有對象之間保持通用并由所有對象共享public Employee(String name,int age){this.name = name;this.age = age;this.ID = nextId++;}public void show(){System.out.println("Id="+ID+"\nName="+name+"\nAge="+age);}public void showNextId(){System.out.println("Next employee id will be="+nextId);}protected void finalize(){--nextId;//在這種情況下,gc 會為 2 個對象調用 finalize() 兩次。} }// 它是 Employee 類的右括號 class UseEmployee {public static void main(String []args){Employee E=new Employee("GFG1",33);Employee F=new Employee("GFG2",45);Employee G=new Employee("GFG3",25);E.show();F.show();G.show();E.showNextId();F.showNextId();G.showNextId();{//這是保留所有實習生的子塊。Employee X=new Employee("GFG4",23); Employee Y=new Employee("GFG5",21);X.show();Y.show();X.showNextId();Y.showNextId();X = Y = null;System.gc();System.runFinalization();}E.showNextId();} }

關注我,不迷路,對就是這個意思!

文章來源:https://www.tuicool.com/articles/ZVZbQz2

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的Java 垃圾回收机制,你知多少??的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。