Skip to content

Latest commit

 

History

History
85 lines (43 loc) · 3.19 KB

插件化技术学习.md

File metadata and controls

85 lines (43 loc) · 3.19 KB

###Android动态加载dex技术初探

http://blog.csdn.net/u013478336/article/details/50734108

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

http://blog.csdn.net/u010687392/article/details/47121729?hmsr=toutiao.io&utm_medium=toutiao.io&utm_source=toutiao.io 为什么引入动态加载技术?

  • 一个应用程序dex文件的方法数最大不能超过65536个
  • 可以让应用程序实现插件化、插拔式结构,对后期维护有益

什么是动态加载技术

动态加载技术就是使用类加载器加载相应的apk、dex、jar(必须含有dex文件),再通过反射获得该apk、dex、jar内部的资源(class、图片、color等等)进而供宿主app使用。

关于动态加载使用的类加载器

  • PathClassLoader - 只能加载已经安装的apk,即/data/app目录下的apk。
  • DexClassLoader - 能加载手机中未安装的apk、jar、dex,只要能在找到对应的路径。

#插件化技术学习

原因:

各大厂商都碰到了AndroidNative平台的瓶颈:

  1. 从技术上讲,业务逻辑的复杂代码急剧膨胀,各大厂商陆续触到65535方法数的天花板;同时,对模块热更新提出了更高的要求。
  2. 在业务层面上,功能模块的解耦以及维护团队的分离也是大势所趋。

插件化技术主要解决两个问题:

  1. 代码加载
  2. 资源加载

###代码加载 类的加载可以使用Java的ClassLoader机制,还需要组件生命周期管理。

###资源加载 用AssetManager的隐藏方法addAssetPath。

##Android插件化原理解析——Hook机制之动态代理

使用代理机制进行API Hook进而达到方法增强。

静态代理

动态代理:可以简单理解为JVM可以在运行时帮我们动态生成一系列的代理类。

###代理Hook

如果我们自己创建代理对象,然后把原始对象替换为我们的代理对象,就可以在这个代理对象中为所欲为了;修改参数,替换返回值,称之为Hook。

整个Hook过程简要总结如下:

  1. 寻找Hook点,原则是静态变量或者单例对象,尽量Hook public的对象和方法,非public不保证每个版本都一样,需要适配。
  2. 选择合适的代理方式,如果是接口可以用动态代理;如果是类可以手动写代理也可以使用cglib。
  3. 偷梁换柱-用代理对象替换原始对象

##Android插件化原理解析——Hook机制之Binder Hook