重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

Android中怎么利用Handler防止内存泄露

今天就跟大家聊聊有关Android中怎么利用Handler防止内存泄露,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

创新互联-专业网站定制、快速模板网站建设、高性价比锡林浩特网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式锡林浩特网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖锡林浩特地区。费用合理售后完善,十年实体公司更值得信赖。

 Handler可能导致的内存泄露及其优化    

  1 关于常见的Handler的用法但是可能导致内存泄露 

  2 优化方式请参考BetterHandler和BetterRunnable的实现

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可能导致的内存泄露及其优化 
 * 
 * 1 关于常见的Handler的用法但是可能导致内存泄露 
 *  请参考方法initHandler() 
 * 2 优化方式请参考BetterHandler和BetterRunnable的实现 
 *  
 *
 * 
 */ 
public class MainActivity extends Activity { 
  private Handler mHandler; 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
  } 
   
   
  /** 
   * 常见的Handler的用法但是可能导致内存泄露 
   * 
   * 比如在旋转屏幕时该Activity重新绘制. 
   * 但是因为mHandler发送了一个延迟消息,所以消息队列持有mHandler对象 
   * 又由于new Runnable(){}持有外部类MainActivity的引用 
   * 所以Activity所占内存并不能向期望的那样被回收,这样就可能会造成内存泄漏. 
   * 
   * 这个例子中Handler的延迟时间比较久有20S,有点极端了,一般不会这么干; 
   * 这里只是为了更好地说明这个问题就这么写代码了。 
   * 
   */ 
  private void initHandler() { 
    mHandler = new Handler() { 
      @Override 
      public void handleMessage(Message msg) { 
        super.handleMessage(msg); 
      } 
    }; 
 
    // ......doing something 
    // ......doing something 
    // ......doing something 
 
    // 发送延迟消息 
    mHandler.postDelayed(new Runnable() { 
      @Override 
      public void run() { 
 
      } 
    }, 1000 * 20); 
  } 
   
   
   
  /** 
   * 以下为优化方式 
   * 1 在此处把BetterHandler和BetterRunnable都设计为静态类, 
   * 这样它们就不会持有外部类的引用了. 
   * 2 在BetterHandler中利用WeakReference持有Activity. 
   * 常听说:"如果一个对象具有弱引用,那么当GC线程扫描的过程中,一旦发现了只具有弱引用的对象,不管当前内存空间足够与否,都会回收它的内存" 
   * 其实准备地说应该是"如果一个对象只具有弱引用.........",即仅有弱引用而不存在对其的强引用才会将其回收. 
   * 那么此处对Activity采用了弱引用,会不会导致该Activity被回收呢? 
   * 答案是否定的。因为此处的Activity还在显示界面,当然存在其他对象对它的强引用。所以不会对其回收。 
   *  
   * 经过这样的优化,当旋转屏幕时需要销毁原Activity时;消息队列持有Handler对象.但此时Handler对象不再持有Activity的引用. 
   * 所以系统会回收该Activity所占内存.所以在handleMessage()中处理消息时需要判断Activity是否为空. 
   * 比如此处20秒后才处理消息 这个时候Activity为空. 
   */ 
  private static class BetterHandler extends Handler{ 
    private final WeakReference activityWeakReference; 
    public BetterHandler(Activity activity){ 
      activityWeakReference=new WeakReference(activity); 
    } 
    @Override 
    public void handleMessage(Message msg) { 
      super.handleMessage(msg); 
      if (activityWeakReference.get()!=null) { 
        //.....handle message 
      } else { 
        System.out.println("Activity==null"); 
      } 
    } 
  } 
   
  //同样采用静态内部类 
  private static class BetterRunnable implements Runnable{ 
    @Override 
    public void run() { 
      // ......doing something 
    } 
     
  } 
   
  //发送延迟消息 
  private void sendMessage(){ 
    BetterHandler betterHandler=new BetterHandler(MainActivity.this); 
    betterHandler.postDelayed(new BetterRunnable(), 1000 * 20); 
  } 
   
 
}

看完上述内容,你们对Android中怎么利用Handler防止内存泄露有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。


当前名称:Android中怎么利用Handler防止内存泄露
标题链接:http://cqcxhl.com/article/jcesoe.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP