几行代码轻松监控Android GC 情况

为什么要监控gc情况

不仅仅是android了,其实只要是java技术这一块的,做性能监控,gc次数/频率 肯定是要做的,服务端那边也有,只不过他们监控的手段和我们不太一样。

但是目的是一样的,gc的频率是影响app流畅性的一个重要指标

android的监控方案

对于低版本的android手机来说,只要发生了gc,log日志是会有相应的日志的。但是高版本这个日志就没了,那么我们如何感知到 android的虚拟机发生了gc呢?

其实android源码里已经有现成的例子了 BinderInternal

其实关键就是一直保留一个弱引用对象,当这个弱引用的对象被回收时,则一定会走到finalize 这个方法内,此时则意味着发生了gc行为

还不算完,你要保证你能一直监控整个app期间的gc行为,那你在finalize这个方法内 要确保 再重新new出来这个弱引用对象,否则 gc一次 你这个对象没了 后面就再也收不到gc了

kotlin的极简实现

kotlin 复制代码
object GcWatcher {
    private var gcWatcher: WeakReference<GcWatcherInternal>? = null
    // 在你application启动的时候 init就行
    @JvmStatic
    fun init() {
        if (gcWatcher == null) {
            gcWatcher = WeakReference(GcWatcherInternal())
        } else {
            Log.v(TAG, "GCWatcher() is inited,dont need init again")
        }
    }

    class GcWatcherInternal {
        @kotlin.jvm.Throws(Throwable::class)
        protected fun finalize() {
            // 每次gc都会走这里 可以在这里统计你想要的次数/频率等信息
            Log.v(TAG, "GcWatcherInternal detect vm do gc !!!!!")
            gcWatcher = WeakReference(GcWatcherInternal())

        }
    }
}

最后你们app冷启动到首屏渲染之间,发生了几次gc呢? 你认为发生多少次gc 是比较理想的情况?

相关推荐
网络研究院1 小时前
Android 安卓内存安全漏洞数量大幅下降的原因
android·安全·编程·安卓·内存·漏洞·技术
凉亭下1 小时前
android navigation 用法详细使用
android
小比卡丘4 小时前
C语言进阶版第17课—自定义类型:联合和枚举
android·java·c语言
前行的小黑炭5 小时前
一篇搞定Android 实现扫码支付:如何对接海外的第三方支付;项目中的真实经验分享;如何高效对接,高效开发
android
落落落sss6 小时前
MybatisPlus
android·java·开发语言·spring·tomcat·rabbitmq·mybatis
代码敲上天.7 小时前
数据库语句优化
android·数据库·adb
GEEKVIP9 小时前
手机使用技巧:8 个 Android 锁屏移除工具 [解锁 Android]
android·macos·ios·智能手机·电脑·手机·iphone
model200511 小时前
android + tflite 分类APP开发-2
android·分类·tflite
彭于晏68911 小时前
Android广播
android·java·开发语言
与衫12 小时前
掌握嵌套子查询:复杂 SQL 中 * 列的准确表列关系
android·javascript·sql