欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android 優(yōu)化Handler防止內(nèi)存泄露

 更新時間:2017年09月04日 10:40:49   作者:lfdfhl  
這篇文章主要介紹了Android 優(yōu)化Handler防止內(nèi)存泄露的相關(guān)資料,這里提供實例幫助大家理解掌握這樣的內(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ū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

最新評論