android基础之(内存泄露)

tech2022-09-17  153

内存泄露: 本质 变量该回收,但是没有被回收,导致出现内存泄露情况,android中常见的情况如:比如多线程造成的内存泄漏,静态变量造成的内存泄漏,单例模式造成的内存泄漏等等.......当然这些不在本篇的范围内,就不过多分析啦。

  1:分析 Handler造成的内存泄漏

   解决这个问题思路就是使用静态内部类并继承Handler时(或者也可以单独存放成一个类文件)。因为静态的内部类不会持有外部类的引用,所以不会导致外部类实例的内存泄露当你需要在静态内部类中调用外部的Activity时,我们可以使用弱引用来处理。另外关于同样也需要将Runnable设置为静态的成员属性。修改后不会导致内存泄露的代码如下:

package com.zejian.handlerlooper; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import java.lang.ref.WeakReference; public class HandlerActivity extends Activity { //创建一个2M大小的int数组 int[] datas=new int[1024*1024*2]; // Handler mHandler = new Handler(){ // @Override // public void handleMessage(Message msg) { // super.handleMessage(msg); // } // }; /** * 创建静态内部类 */ private static class MyHandler extends Handler{ //持有弱引用HandlerActivity,GC回收时会被回收掉. private final WeakReference<HandlerActivity> mActivty; public MyHandler(HandlerActivity activity){ mActivty =new WeakReference<HandlerActivity>(activity); } @Override public void handleMessage(Message msg) { HandlerActivity activity=mActivty.get(); super.handleMessage(msg); if(activity!=null){ //执行业务逻辑 } } } private static final Runnable myRunnable = new Runnable() { @Override public void run() { //执行我们的业务逻辑 } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_handler_leak); MyHandler myHandler=new MyHandler(this); //解决了内存泄漏,延迟5分钟后发送 myHandler.postDelayed(myRunnable, 1000 * 60 * 5); } }

 

最新回复(0)