Android 动态加载 dex 技术初探
Android使用Dalvik虚拟机加载可执行程序,所以不能直接加载基于class的jar,而是需要将class转化为dex字节码。
Android支持动态加载的两种方式是:DexClassLoader和PathClassLoader,DexClassLoader可加载jar/apk/dex,且支持从SD卡加载;PathClassLoader据说只能加载已经安装在Android系统内APK文件。
Android 插件化基础
Android 简单来说就是如下操作:
- 开发者将插件代码封装成Jar或者APK
- 宿主下载或者从本地加载Jar或者APK到宿主中
- 将宿主调用插件中的算法或者Android特定的Class(如Activity)
插件化开发—动态加载技术加载已安装和未安装的apk
为什么引入动态加载技术?
- 一个应用程序dex文件的方法数最大不能超过65536个
- 可以让应用程序实现插件化、插拔式结构,对后期维护有益
什么是动态加载技术
动态加载技术就是使用类加载器加载相应的apk、dex、jar(必须含有dex文件),再通过反射获得该apk、dex、jar内部的资源(class、图片、color等等)进而供宿主app使用。
关于动态加载使用的类加载器
- PathClassLoader - 只能加载已经安装的apk,即/data/app目录下的apk。
- DexClassLoader - 能加载手机中未安装的apk、jar、dex,只要能在找到对应的路径。
插件化技术学习
原因:
各大厂商都碰到了AndroidNative平台的瓶颈:
- 从技术上讲,业务逻辑的复杂代码急剧膨胀,各大厂商陆续触到65535方法数的天花板;同时,对模块热更新提出了更高的要求。
- 在业务层面上,功能模块的解耦以及维护团队的分离也是大势所趋。
插件化技术主要解决两个问题:
- 代码加载
- 资源加载
代码加载
类的加载可以使用Java的ClassLoader机制,还需要组件生命周期管理。
资源加载
用AssetManager的隐藏方法addAssetPath。
Android插件化原理解析——Hook机制之动态代理
使用代理机制进行API Hook进而达到方法增强。
静态代理
动态代理:可以简单理解为JVM可以在运行时帮我们动态生成一系列的代理类。
代理Hook
如果我们自己创建代理对象,然后把原始对象替换为我们的代理对象,就可以在这个代理对象中为所欲为了;修改参数,替换返回值,称之为Hook。
整个Hook过程简要总结如下:
- 寻找Hook点,原则是静态变量或者单例对象,尽量Hook public的对象和方法,非public不保证每个版本都一样,需要适配。
- 选择合适的代理方式,如果是接口可以用动态代理;如果是类可以手动写代理也可以使用cglib。
- 偷梁换柱-用代理对象替换原始对象
Android插件化原理解析——Hook机制之Binder Hook