版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
內(nèi)存的優(yōu)低內(nèi)存對象的的級在JDK1.2以前的版本中,若一個(gè)對象不被任何變量,那么程序就無法再使用這個(gè)從JDK1.2版本開始,把對象的分為4種級別,從而使程序能更加靈活地控制對象這4種級別由高到低依次為:強(qiáng)、軟、弱和虛強(qiáng)如:Objectobjectnew強(qiáng)是使用最普遍的如果一個(gè)對象具有強(qiáng)那回收器絕不會(huì)回收它內(nèi)存不足時(shí)寧拋異常OOM,軟通過“袋子”(sr)來拿“內(nèi)容”(JDK通過“袋子”(sr)來拿“內(nèi)容”(Objectobject=new(內(nèi)容SoftReferencesr=new//將object對Objectobject=new(內(nèi)容SoftReferencesr=new//將object對象級別降一旦SoftReference保存了對一個(gè)Java對象的軟后在線程對這個(gè)Java對象回收前另外,一旦線程回收該Java對象之后,get()方法將返回null;軟可以和一個(gè)隊(duì)列(ReferenceQueue)聯(lián)合使用,如果軟所的對象被回收器回收,Java虛擬機(jī)就會(huì)把這個(gè)軟加入到與之關(guān)聯(lián)的隊(duì)列中ObjectObjectobject=new(內(nèi)容SoftReferencesr=new(袋子//將object對象級別降:一個(gè)是來自SoftReference對象的軟一個(gè)來自變量object的強(qiáng),所以這個(gè)Object對象是強(qiáng)可及對象;隨即,我們可以結(jié)束object對這個(gè)Object實(shí)例的強(qiáng):object=如果收集線程進(jìn)行內(nèi)存收集,并不會(huì)因?yàn)橛幸粋€(gè)SoftReference對該對象的而Java虛擬機(jī)的收集線程對軟可及對象和其他一般Java對象進(jìn)行了區(qū)別對待:軟可及對象的清理是由收集線程根據(jù)其特定算法按照內(nèi)存需求決定的。也就是說,收集線程會(huì)在虛擬機(jī)拋出OutOfMemoryError之前回收軟可及對象,而弱弱與軟的區(qū)別:只具有弱的對象擁有更短暫的生命周期。生命周期比軟更短在回收器線程掃描它所管轄的內(nèi)存區(qū)域的過程中,一旦發(fā)現(xiàn)了只具有弱的有弱的對象;類似于軟,弱也可以和一個(gè)隊(duì)列(ReferenceQueue)聯(lián)合使用,如果弱所的對象被回收,Java虛擬機(jī)就會(huì)把這個(gè)弱加入到與之關(guān)聯(lián)的隊(duì)列虛 可用來對象被回收器回收的活動(dòng)虛與軟和弱的一個(gè)區(qū)別在于虛必須和隊(duì)列(ReferenceQueue)聯(lián)合使用當(dāng)回收器準(zhǔn)備回收一個(gè)對象時(shí),如果發(fā)現(xiàn)它還有虛,就會(huì)在回收對象的內(nèi)存之前,把這個(gè)虛加入到與之關(guān)聯(lián)的隊(duì)列中;ReferenceQueue與軟結(jié)合使,隊(duì)列,在檢測到適當(dāng)?shù)目傻竭_(dá)性更改后回收器將已的對象添加到該,get()null;SoftReference對象已經(jīng)不再具有存在的價(jià)值,需要一個(gè)適當(dāng)?shù)那宄龣C(jī)制,避免SoftReference對象帶來的內(nèi)存泄漏。Objectobject=new(內(nèi)容Objectobject=new(內(nèi)容多的對ReferenceQueuequeuenew //裝 SoftReferencesr=newSoftReference(object, 那么當(dāng)這個(gè)SoftReference所軟的object被收集器回收的同時(shí),sr所強(qiáng)也就是說,ReferenceQueueReference對象,而且是已經(jīng)失去了它所軟Reference對象。poll()方法的時(shí)候,如果這個(gè)隊(duì)列中不是空隊(duì)列,那么將返回隊(duì)列前面Reference對象。null,Reference對象。利用這個(gè)方法,我們可以檢查哪個(gè)SoftReference所軟的對象已經(jīng)被回收。軟的示例(在中的UIManager類中UIManagerMap值)UIManagerMap對象;SoftHashMapSoftHashMap;軟SoftHashMap實(shí)現(xiàn)步驟map信息;當(dāng)GC回收軟實(shí)例之后,需要利用GC幫助我們完成回收掉的軟集合軟SoftHashMap的代碼(最終版軟SoftHashMap的代碼(最終版 @param*@parampublicclassSoftHashMap<K,V>extendsHashMap<K,V>//降低對象的1.將V2.回收“袋子privateHashMap<K,MySoftReference<K,V>>privateReferenceQueue<V //裝V的袋子的隊(duì)publicSoftHashMap()softMap=newHashMap<K,MySoftReference<K,=new}/**重寫放入數(shù)據(jù)方法*/publicVput(Kkey,Vvalue)//占用內(nèi)存較多的對象包了一層袋子,GC時(shí),會(huì)往queue中加“MySoftReference”的MySoftReference<KVsrValuenewMySoftReference<KV>(keyvalue,queue);softMap.put(keysrValue);return}/**重寫獲取方法*/publicVget(Objectkey) //先清理空袋MySoftReference<K,V>sr=if(sr!=null)return // 的對象,即袋子中的內(nèi)}return}/**重寫containsKey方法*/publicbooleancontainsKey(Objectkey)return}/**回收“空袋子”*/privatevoidclearNullSR//方案1:遍歷softMap中的所有元素,如發(fā)現(xiàn)V=null,在softMap//方法2:讓GC記錄回收的內(nèi)容(集合中 空袋子 的
MySoftReference<K,V>poll=(MySoftReference<K,V>)while(poll!=null){poll=(MySoftReference<K,V>)}}/**加強(qiáng)版的袋子(包裝設(shè)計(jì)模式的應(yīng)用): 一下key*/privateclassMySoftReference<K,V>extendsSoftReference<V>privateObject //為袋子添加一 ,即為map中的publicMySoftReference(Kkey,Vr,ReferenceQueue<?superV>q)super(r,this.key=}}}}/*********需要內(nèi)容優(yōu)化/*********需要內(nèi)容優(yōu)化100個(gè)界面,內(nèi)存不足是,釋放掉map /**緩存BaseView的子類Map,key為類的簡單名稱privatestaticMap<String,BaseView>baseViewMap=newHashMap<String,staticif(MemoryManager.hasAcailMemory())}else //構(gòu)建 }}@returnfalse表示模擬的Activity的“棧”中沒有viewtrue表示移除當(dāng)前publicbooleangoBack(){Stringkey="";if(historyStack.size()>0)key=}if(StringUtils.isNotBlank(key))//棧頂//依據(jù)keyif(targetView!=null)if(targetView.getClasscurrentView.getClassif(historyStack.size()==1)//判斷return}return}elseif(currentView!=null){}currentView=return}}else //提示用戶--//回到首頁}}return}硬指定內(nèi)存大小,一旦滿了,會(huì)丟棄一部分內(nèi)容至軟的集合中,可以被系統(tǒng)GC了,軟SoftHashMap的代碼(初版* @param@parampublicclassSoftHashMap1<K,V>extendsHashMap<K,V>//降低對象的 privateHashMap<K,SoftReference<V>>publicSoftHashMap1()softMap=newHashMap<K,}publicVput(Kkey,Vvalue)SoftReference<V>srValue=newsoftMap.put(key,return}publicVget(Objectkey)SoftReference<V>sr=key與殼綁returnreturn}// publicbooleancontainsKey
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年度安全生產(chǎn)月宣傳品采購與分發(fā)合同
- 2024年度建設(shè)施工合同工程質(zhì)量與工程款支付規(guī)定
- 2024年企業(yè)環(huán)保設(shè)施建設(shè)和運(yùn)營合同
- 04版離婚合同:三個(gè)孩子的監(jiān)護(hù)權(quán)、財(cái)產(chǎn)分配及贍養(yǎng)費(fèi)
- 2024聘用駕駛員合同書
- 2024年建筑基礎(chǔ)土石方作業(yè)合同
- 安利心態(tài)課件教學(xué)課件
- 催收員試用期轉(zhuǎn)正工作總結(jié)(6篇)
- 2024年度ABC電子科技有限公司手機(jī)代理銷售合同
- 2024年大型物流中心建設(shè)與運(yùn)營合同
- 2024年房屋裝修工程合同
- 《魏書生班主任工作漫談》讀書心得體會(huì)課件
- 第16課 國家出路的探索與列強(qiáng)侵略的加劇 課件上學(xué)期統(tǒng)編版(2019)必修中外歷史綱要上
- 2024年四川雷波縣“123”林業(yè)技術(shù)人才定向培養(yǎng)畢業(yè)生招聘擬聘易考易錯(cuò)模擬試題(共500題)試卷后附參考答案
- 白求恩人物生平紀(jì)念
- 2024年度陜西榆林能源集團(tuán)限公司高校畢業(yè)生招聘(238人)高頻難、易錯(cuò)點(diǎn)500題模擬試題附帶答案詳解
- 零工市場(驛站)運(yùn)營管理投標(biāo)方案(技術(shù)方案)
- 2024-2025學(xué)年小學(xué)信息技術(shù)(信息科技)四年級下冊浙教版(2023)教學(xué)設(shè)計(jì)合集
- 旅游紙質(zhì)合同模板
- 飛機(jī)維修計(jì)劃與調(diào)度管理考核試卷
- 中國鹽業(yè)集團(tuán)有限公司招聘筆試題庫2024
評論
0/150
提交評論