从GcRoot角度来分析Handler 内存泄漏

本文从GCRoot的角度详细分析了Handler如何持有Activity引用导致内存泄漏,解释了匿名内部类如何持有外部类引用,以及内存泄漏发生的条件。通过可达性分析算法,揭示了Handler、Message、Looper和静态变量sThreadLocal之间的引用关系,指出在任务未执行完时,由于静态变量的存在,导致Activity无法被回收。文章还讨论了避免内存泄漏的可能方案,如在destroy时移除消息或使用WeakReference包裹Activity,但后者存在风险。
摘要由CSDN通过智能技术生成

从GCRoot角度来分析Handler 内存泄漏

引言

看了好多博客发现都只说了handler会有内存泄漏风险,原因是handler持有了activity的引用。
但是为什么会发生内存泄漏,好像都没讲清楚。
我研究了一下,说一下我的理解。

开始分析

下面我们就来分析内存泄漏的具体原因,我们分两步来说。

  1. handler是怎么持有Activity引用的
  2. handler是怎么发生内存泄漏的
handler是怎么持有Activity引用的

Handler的使用,如果不考虑内存泄漏问题,我们一般都这么用,直接在activity中声明handler,并实现handleMessage方法。

public class MainActivity extends AppCompatActivity {
   

Handler handler = new Handler(){
   
        @Override
        public void handleMessage(@NonNull Message msg) 
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值