項(xiàng)目總結(jié)知識(shí)點(diǎn)手機(jī)android內(nèi)存優(yōu)化_第1頁
項(xiàng)目總結(jié)知識(shí)點(diǎn)手機(jī)android內(nèi)存優(yōu)化_第2頁
項(xiàng)目總結(jié)知識(shí)點(diǎn)手機(jī)android內(nèi)存優(yōu)化_第3頁
已閱讀5頁,還剩3頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論