LeakCanary在Android 10设备上的提示Activity(IRequestFinishCallback$Stub)内存泄露问题

it2025-01-27  15

在Android 10的设备上开发应用,使用LeakCanary对应用进行内存泄露检查,发现在activity中点击返回键回到桌面,会发现LeakCanary触发了一个内存泄露的提示,大致如下图所示:

在LeakCanary中也有相关的提示,大致意思就是:在Adnroid Q及之后的Android版本在Activity中添加了一个名为IRequestFinishCallback的匿名内部类,在当Activity调用了onDestory后,IRequestFinishCallback的引用还在被其他进程所回调,所以这里会导致Activity无法正常释放,从而造成的了内存泄露。

其他这里LeakCanary也大致描述的很清楚,所以接下来我们直接看下Android 10的源代码,看下是否如LeakCanary所描述。

Activity的源代码位置:

../frameworks/base/core/java/android/app/Activity.java

我们直接看关键方法:onBackPressed()

看到此处源码时,相信大部分人就很明白了——这里是一个典型的Handler造成Activity泄露的问题。匿名AIDL回调中引用了mHandler这个内部变量,当onDestory()调用后,mHandler则继续被引用导致Activty无法正常释放,从而导致了泄露。

在Android的问题反馈论坛也有该问题的相关信息的反馈,Google也确定了这个问题是Android的一个BUG会再将来的版本进行修复。

[Android Q Beta] Memory leak in IRequestFinishCallback$Stub

在笔者写这篇博客的时候(2020-10),Google已经对该问题进行了修复,可以再看下修改之后的方法。

那么如果作为一般应用开发者,无法接触源码如何解决这个问题呢?

一般的方法就是直接在Activity重写onBackPressed()方法,不用super.onBackPressed(),直接调用finishAfterTransition()就行了。

最新回复(0)