Android 優(yōu)化Handler防止內(nèi)存泄露
Android 優(yōu)化Handler防止內(nèi)存泄露
Demo描述:
Handler可能導(dǎo)致的內(nèi)存泄露及其優(yōu)化
1 關(guān)于常見的Handler的用法但是可能導(dǎo)致內(nèi)存泄露
2 優(yōu)化方式請參考BetterHandler和BetterRunnable的實現(xiàn)
package cc.cc;
import java.lang.ref.WeakReference;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.app.Activity;
/**
* Demo描述:
* Handler可能導(dǎo)致的內(nèi)存泄露及其優(yōu)化
*
* 1 關(guān)于常見的Handler的用法但是可能導(dǎo)致內(nèi)存泄露
* 請參考方法initHandler()
* 2 優(yōu)化方式請參考BetterHandler和BetterRunnable的實現(xiàn)
*
*
*
*/
public class MainActivity extends Activity {
private Handler mHandler;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
/**
* 常見的Handler的用法但是可能導(dǎo)致內(nèi)存泄露
*
* 比如在旋轉(zhuǎn)屏幕時該Activity重新繪制.
* 但是因為mHandler發(fā)送了一個延遲消息,所以消息隊列持有mHandler對象
* 又由于new Runnable(){}持有外部類MainActivity的引用
* 所以Activity所占內(nèi)存并不能向期望的那樣被回收,這樣就可能會造成內(nèi)存泄漏.
*
* 這個例子中Handler的延遲時間比較久有20S,有點極端了,一般不會這么干;
* 這里只是為了更好地說明這個問題就這么寫代碼了。
*
*/
private void initHandler() {
mHandler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
}
};
// ......doing something
// ......doing something
// ......doing something
// 發(fā)送延遲消息
mHandler.postDelayed(new Runnable() {
@Override
public void run() {
}
}, 1000 * 20);
}
/**
* 以下為優(yōu)化方式
* 1 在此處把BetterHandler和BetterRunnable都設(shè)計為靜態(tài)類,
* 這樣它們就不會持有外部類的引用了.
* 2 在BetterHandler中利用WeakReference持有Activity.
* 常聽說:"如果一個對象具有弱引用,那么當(dāng)GC線程掃描的過程中,一旦發(fā)現(xiàn)了只具有弱引用的對象,不管當(dāng)前內(nèi)存空間足夠與否,都會回收它的內(nèi)存"
* 其實準(zhǔn)備地說應(yīng)該是"如果一個對象只具有弱引用.........",即僅有弱引用而不存在對其的強引用才會將其回收.
* 那么此處對Activity采用了弱引用,會不會導(dǎo)致該Activity被回收呢?
* 答案是否定的。因為此處的Activity還在顯示界面,當(dāng)然存在其他對象對它的強引用。所以不會對其回收。
*
* 經(jīng)過這樣的優(yōu)化,當(dāng)旋轉(zhuǎn)屏幕時需要銷毀原Activity時;消息隊列持有Handler對象.但此時Handler對象不再持有Activity的引用.
* 所以系統(tǒng)會回收該Activity所占內(nèi)存.所以在handleMessage()中處理消息時需要判斷Activity是否為空.
* 比如此處20秒后才處理消息 這個時候Activity為空.
*/
private static class BetterHandler extends Handler{
private final WeakReference<Activity> activityWeakReference;
public BetterHandler(Activity activity){
activityWeakReference=new WeakReference<Activity>(activity);
}
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
if (activityWeakReference.get()!=null) {
//.....handle message
} else {
System.out.println("Activity==null");
}
}
}
//同樣采用靜態(tài)內(nèi)部類
private static class BetterRunnable implements Runnable{
@Override
public void run() {
// ......doing something
}
}
//發(fā)送延遲消息
private void sendMessage(){
BetterHandler betterHandler=new BetterHandler(MainActivity.this);
betterHandler.postDelayed(new BetterRunnable(), 1000 * 20);
}
}
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- 總結(jié)Android App內(nèi)存優(yōu)化之圖片優(yōu)化
- Android性能優(yōu)化之利用強大的LeakCanary檢測內(nèi)存泄漏及解決辦法
- 詳解Android的內(nèi)存優(yōu)化--LruCache
- Android性能優(yōu)化之利用Rxlifecycle解決RxJava內(nèi)存泄漏詳解
- Android Bitmap詳解及Bitmap的內(nèi)存優(yōu)化
- 淺談Android性能優(yōu)化之內(nèi)存優(yōu)化
- 詳解Android內(nèi)存泄露及優(yōu)化方案
- 詳解Android內(nèi)存優(yōu)化策略
- Android?內(nèi)存優(yōu)化知識點梳理總結(jié)
相關(guān)文章
Android UI之ImageView實現(xiàn)圖片旋轉(zhuǎn)和縮放
這篇文章主要介紹了Android UI之ImageView實現(xiàn)圖片旋轉(zhuǎn)和縮放的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2015-09-09
ScrollView與SeekBar綁定實現(xiàn)滑動時出現(xiàn)小滑塊效果
這篇文章主要為大家詳細(xì)介紹了ScrollView與SeekBar綁定實現(xiàn)滑動時出現(xiàn)小滑塊效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10
Android學(xué)習(xí)筆記之藍(lán)牙功能
這篇文章主要為大家詳細(xì)介紹了Android學(xué)習(xí)筆記之藍(lán)牙功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-09-09
android基于dialog實現(xiàn)等待加載框示例
本篇文章主要介紹了android基于dialog實現(xiàn)等待加載框示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02
Android實現(xiàn)基于ViewPager的無限循環(huán)自動播放帶指示器的輪播圖CarouselFigureView控件
這篇文章主要介紹了Android實現(xiàn)基于ViewPager的無限循環(huán)自動播放帶指示器的輪播圖CarouselFigureView控件,需要的朋友可以參考下2017-02-02

