alreadyandroidAndroid 开发者必会

Carson带你学Android:这是一份全面&详细的热补丁(修

2021-10-11  本文已影响0人  Carson带你学安卓

前言

Carson带你学Android系列文章
Carson带你学Android:学习方法
Carson带你学Android:四大组件
Carson带你学Android:自定义View
Carson带你学Android:异步-多线程
Carson带你学Android:性能优化
Carson带你学Android:动画


目录

示意图

1. 简介

示意图

2. 储备知识

2.1 Android Dex 分包方案

示意图 示意图

2.2 Android 类加载机制(ClassLoader)

示意图

注:若2个Dex文件中有重复的类,当加载时,则优先加载排序较前的Dex文件的类

若所需加载类 = class3,则最终加载的是排序较前的Dex1文件中的class3

示意图
 /**
    * 加载流程说明
    **/
    // 1. 传入需加载类的名字(classname)
    // 2. 通过Dex文件,寻找到所需类(findClass) 
        // a. 按顺序遍历ClassLoader的所有Dex文件,即 集合dexElements
        // b. 每遍历到1个Dex文件,则在该Dex文件中寻找所需加载的类
        // c. 若在该Dex文件找到该类,则返回;若找不到,则继续遍历下1个Dex文件
    // 3. 加载所需类

  /**
    * BaseDexClassLoader的findClass()源码分析
    **/
    @Override
    protected Class<?> findClass(String name) throws ClassNotFoundException {

        // 从pathList对象对象中寻找->>分析1
        Class clazz = pathList.findClass(name);

        if (clazz == null) {
            throw new ClassNotFoundException(name);
        }

        return clazz;
    }

  /**
    * 分析1:DexPathList的findClass()源码分析
    **/
    public Class findClass(String name) {
        // 1. 按顺序遍历ClassLoader的所有Dex文件,即 集合dexElements
        for (Element element : dexElements) {
            DexFile dex = element.dexFile;
            
            // 2. 每遍历到1个Dex文件,则在该Dex文件中寻找所需加载的类 ->>分析2
            if (dex != null) {
                Class clazz = dex.loadClassBinaryName(name, definingContext);
                // 3. 若在该Dex文件找到该类,则返回;若找不到,则继续遍历下1个Dex文件
                if (clazz != null) {
                    return clazz;
                }
            }
        }

        return null;
    }

  /**
    * 分析2:DexFile的loadClassBinaryName()源码分析
    **/
    public Class loadClassBinaryName(String name, ClassLoader loader) {
        return defineClass(name, loader, mCookie);
    }

  /**
    * 分析3:DexFile的defineClass()源码分析
    **/
    private native static Class defineClass(String name, ClassLoader loader, int cookie);


3. 热修复 原理

3.1 具体描述

  1. 把需修复、含Bug的类 独立打包到1个Dex文件中(记为:patch.dex
  2. 将该 Dex文件 插入到ClassLoader中集合 dexElements的最前面

3.2 示意图

示意图

3.3 特别注意:CLASS_ISPREVERIFIED 标记

示意图 示意图

注:需完成上述步骤(防止类被打上 CLASS_ISPREVERIFIED 标记),再实现补丁


4. 热修复 开源库介绍

4.1 主流的热修复 开源库

库名 作者 Github地址
Tinker 腾讯 微信团队 https://github.com/Tencent/tinker
Nuwa 腾讯 QQ空间团队 https://github.com/Tencent/tinker
Dexposed 阿里 手机淘宝团队 https://github.com/alibaba/dexposed
AndFix 阿里 支付宝团队 https://github.com/alibaba/AndFix

4.2 对比

示意图

5. 总结

相关系列文章阅读
Carson带你学Android:学习方法
Carson带你学Android:四大组件
Carson带你学Android:自定义View
Carson带你学Android:异步-多线程
Carson带你学Android:性能优化
Carson带你学Android:动画


欢迎关注Carson_Ho的简书

不定期分享关于安卓开发的干货,追求短、平、快,但却不缺深度


请点赞!因为你的鼓励是我写作的最大动力!

上一篇 下一篇

猜你喜欢

热点阅读