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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

的引用_java中的强引用,软引用,弱引用,虚引用

發布時間:2024/1/23 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 的引用_java中的强引用,软引用,弱引用,虚引用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一對象回收算法

Java在GC時判斷對象是否存活有兩種方式;第一種是引用計數方式,第二種是可達性分析算法;

引用計數器算法:

在對象中添加一個引用計數器,每當有一個地方引用它時,計數器值就加一;當引用失效時,計數器值就減一;任何時刻計數器為零的對象就是不可用對象

額外占用空間,高效;

可達性分析算法:

從gc roots 往下搜索,走過的路徑稱為引用鏈,如果引用鏈斷開說明對象不可達標記為可回收對象;如果引用鏈連續說明此對象可達標記為不可回收對象。如圖所示,object4,object5,object7都是被標記為可回收對象。

jdk1.2版本之前 如果一個對象沒有被引用,則無法使用這個對象;jdk1.2版本之后對象被分為4個引用級別,由高到低依次為:強引用、軟引用、弱引用和虛引用;開發人員可以利用對象的引用級別靈活控制對象的生命周期。

二強引用(StrongReference)

強引用是指引用賦值,即Objecto bj = new Object()。無論任何情況下,只要強引用關系還存在,垃圾收集器就永遠不會回收掉被引用的對象。

如下方式都是強引用

Object obj = new Object(); String str = "zszxz";

如果一個對象具有強引用,不會被垃圾回收器回收。當內存空間不足,Java虛擬機寧愿拋出OutOfMemoryError錯誤,使程序異常終止,也不回收對象,故通常如果對象不用的時候就需要手動賦值為 null, 方便垃圾回收器回收

示例

String str = null;

當然 通常對象不會手動賦值為null, 只有比較大的對象集合時就需要手動賦值,比如 ArrayList 里面的 clear() 方法。

public void clear() {modCount++; ?// clear to let GC do its workfor (int i = 0; i < size; i++)elementData[i] = null; ?size = 0;}注:養成手動釋放內存能提示程序性能

三軟引用(SoftReference)

軟引用是用來描述一些還有用,但非必須的對象。只被軟引用關聯著的對象,在系統將要發生內存溢出異常前,會把這些對象列進回收范圍之中進行第二次回收,如果這次回收還沒有足夠的內存,才會拋出內存溢出異常;

源碼:

// 時間戳,右垃圾回收器更新static private long clock; ?// 時間戳,通過get方法調用更新,選擇軟引用時將被清除,VM可以使用這個字段,并非必須private long timestamp; ? ?public SoftReference(T referent) {// 構造器,給對象注入一個軟引用super(referent);this.timestamp = clock;} ?// 給對象注入一個軟引用,并且注入隊列public SoftReference(T referent, ReferenceQueue<? super T> q) {super(referent, q);this.timestamp = clock;} ?// 返回對象的引用,如果引用對象已經被清除或者垃圾回收,則返回Nullpublic T get() {T o = super.get();if (o != null && this.timestamp != clock)this.timestamp = clock;return o;}

如下方式,即使發生gc,只要內存沒有溢出就不會回收軟引用

public static void main(String[] args) throws InterruptedException {// 給對象注入軟引用SoftReference<String> reference = new SoftReference<>(new String("zszxz"));// zszxzSystem.out.println(reference.get());// 調用GCSystem.gc();TimeUnit.SECONDS.sleep(5);// zszxzSystem.out.println(reference.get());}適用于緩存場景

四弱引用(WeakReference)

當垃圾收集器開始工作,無論當前內存是否足夠,都會回收掉被弱引用關聯的對象;

源碼:

public class WeakReference<T> extends Reference<T> {// 給對象注入弱引用public WeakReference(T referent) {super(referent);} ?// 給對象注入一個弱引用并注入引用隊列public WeakReference(T referent, ReferenceQueue<? super T> q) {super(referent, q);} ? }

如下方式,一旦GC調用則會回收對象。

public static void main(String[] args) throws InterruptedException {WeakReference<String> weakReference = new WeakReference<>(new String("zszxz"));// zszxzSystem.out.println(weakReference.get());// 調用GCSystem.gc();TimeUnit.SECONDS.sleep(5);// zszxzSystem.out.println(weakReference.get());}

五虛引用(PhantomReference)

為一個對象設置虛引用關聯的唯一目的只是為了能在這個對象被收集器回收時收到一個系統通知,除此之外沒有任何作用,不決定對象的生命周期;

源碼

public class PhantomReference<T> extends Reference<T> { ?// 獲得引用public T get() {return null;} ?// 創建虛引用public PhantomReference(T referent, ReferenceQueue<? super T> q) {super(referent, q);} ? }

如下示例,即使不調用GC,引用也是為null。

public static void main(String[] args) throws InterruptedException {// 引用隊列ReferenceQueue queue = new ReferenceQueue();PhantomReference reference = new PhantomReference(new String("zszxz"),queue);// nullSystem.out.println(reference.get());}

六總結

  • 強引用:從來不會被回收
  • 軟引用:當內存不足時會被回收
  • 弱引用:正常垃圾回收時回收
  • 虛引用:任何時刻都會被垃圾回收器回收

關注公眾號:知識追尋者 獲取原創PDF,面試題

總結

以上是生活随笔為你收集整理的的引用_java中的强引用,软引用,弱引用,虚引用的全部內容,希望文章能夠幫你解決所遇到的問題。

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