Java中的WeakHashMap淺析
WeakHashMap介紹
- weakhashmap優(yōu)化jvm,是GC更加智能回收無用的對象。
- weakhashmap關鍵是:當一個對象被GC回收時,響應的值對象的引用從map中刪除,weakhaskmap能節(jié)約存儲空間,來實現(xiàn)緩存那些非必要的數(shù)據(jù)
引用類型
java中提供的引用類型有4種
- 強(Strong)引用
- 軟(soft)引用
- 弱(weak)引用
- 虛( phantom)引用
強(Strong)引用
常使用的引用類型,在創(chuàng)建對象時

只要強引用存在,GC永遠不會回收被引用的對象,通過new創(chuàng)建的對象所關聯(lián)引用就是強引用,此時GC就不會碰該對象,當jvm內(nèi)存空間不足,jvm寧愿拋出OOM(OutOfMemoryError)運行時村務,使得程序終止,也不會隨時回收強引用所引用的對象 java中除了強引用還有三種引用,在java.lang.ref.Reference

//referent為引用指向的對象
Reference(T referent) {
this(referent, null);
}
//ReferenceQueue對象,可以理解為隊列
Reference(T referent, ReferenceQueue<? super T> queue) {
this.referent = referent;
this.queue = (queue == null) ? ReferenceQueue.NULL : queue;
}Object o=new Object(); SoftReferencr sr=new SoftReference(o,queue);
sr為軟引用,指向O對象,o會在一定實際被垃圾回收器進行回收,sr對象本身的清理依賴Queue,當sr出現(xiàn)在Queue時,說明指向?qū)ο笠呀?jīng)無效了,可以放心清理
軟(soft)引用
軟引用用來處理啊一些有用但非必須對象,對于軟引用所作用的對象,當內(nèi)存空間充足時,如果發(fā)生GC操作,軟引用所作用的對象是不會被回收的,當空間 不足時,GC操作時軟引用所作用的對象才會被回收
public static void softReferenceDemo(){<!--{C}%3C!%2D%2D%20%2D%2D%3E--> Object o = new Object(); ReferenceQueue <Object> referenceQueue = new ReferenceQueue <Object>(); SoftReference <Object> softReference = new SoftReference <Object>(o, referenceQueue); System.out.println(softReference.get()); System.out.println(softReference.isEnqueued()); System.out.println(referenceQueue.poll()); /** * java.lang.Object@4aa594e1 * false * null */ /** * 當對象被回收時,他會放入到referenceQueue實例中 */ //創(chuàng)建比較大的對象,模擬內(nèi)存不足,觸發(fā)GC,回收軟引用對象 byte[] bytes = new byte[7*1024*1024]; System.gc(); //手動觸發(fā)GC /** * 理論上空間不足,對象會被回收,隊列中會有軟引用對象 */ System.out.println(softReference.get()); System.out.println(softReference.isEnqueued()); System.out.println(referenceQueue.poll()); /** * java.lang.Object@4aa594e1 false null 空間充足,未回收 */ } public static void softReferenceDemo(){
Object o = new Object();
ReferenceQueue <Object> referenceQueue = new ReferenceQueue <Object>();
SoftReference <Object> softReference = new SoftReference <Object>(o, referenceQueue);
System.out.println(softReference.get());
System.out.println(softReference.isEnqueued());
System.out.println(referenceQueue.poll());
/**
* java.lang.Object@4aa594e1
* false
* null
*/
/**
* 當對象被回收時,他會放入到referenceQueue實例中
*/
//創(chuàng)建比較大的對象,模擬內(nèi)存不足,觸發(fā)GC,回收軟引用對象
byte[] bytes = new byte[7*1024*1024];
System.gc(); //手動觸發(fā)GC
/**
* 理論上空間不足,對象會被回收,隊列中會有軟引用對象
*/
System.out.println(softReference.get());
System.out.println(softReference.isEnqueued());
System.out.println(referenceQueue.poll());
/**
*
java.lang.Object@4aa594e1
false
null
空間充足,未回收
*/
}弱(weak)引用
弱引用他的強度會比軟引用更弱一些,被軟引用所關聯(lián)的對象,當發(fā)生GC操作時,無論當前空間是否充足,都會回收軟引用所作用的對象,生命周期會更加短暫
public static void weakReferenceDemo(){
Object o = new Object();
ReferenceQueue <Object> referenceQueue = new ReferenceQueue <Object>();
WeakReference <Object> weakReference = new WeakReference<Object>(o, referenceQueue);
System.out.println(weakReference.get());
System.out.println(weakReference.isEnqueued());
System.out.println(referenceQueue.poll());
System.gc(); //手動觸發(fā)GC
System.out.println(weakReference.get());
System.out.println(weakReference.isEnqueued());
System.out.println(referenceQueue.poll());
}weakHashMap實現(xiàn)就是基于弱來實現(xiàn)的
虛引用
虛引用是最弱的引用關系,一個對象是否有虛引用的存在,不會影響對象的聲明周期,虛引用存在的目的是當對象被回收時收到一個系統(tǒng)通知
public static void phantomferenceDemo(){
Object o = new Object();
ReferenceQueue <Object> referenceQueue = new ReferenceQueue <Object>();
PhantomReference <Object> phantomReference = new PhantomReference<Object>(o, referenceQueue);
o = null;
System.gc(); //手動觸發(fā)GC
if (phantomReference.isEnqueued()) {
System.out.println("正在被回收");
} else {
System.out.println("沒有被回收");
}
}到此這篇關于Java中的WeakHashMap淺析的文章就介紹到這了,更多相關Java的WeakHashMap內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Spring Security OAuth2 token權限隔離實例解析
這篇文章主要介紹了Spring Security OAuth2 token權限隔離實例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-11-11
深入理解@component與@Configuration注解
這篇文章主要介紹了深入理解@component與@Configuration注解,從Spring3.0,@Configuration用于定義配置類,可替換xml配置文件,被注解的類內(nèi)部包含有一個或多個被@Bean注解的方法,這些方法將會被掃描,并用于構建bean定義,初始化Spring容器,需要的朋友可以參考下2023-11-11
解決SpringBoot內(nèi)嵌Tomcat并發(fā)容量的問題
這篇文章主要介紹了解決SpringBoot內(nèi)嵌Tomcat并發(fā)容量的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06

