android原生应用开发发展到今天几乎每个App都是巨无霸级的大小手淘优酷这种应用更是航母级别的应用一个应用可能几百人一起合作开发在应用还小的时候大家可以甜蜜的合作快速的迭代就像孩子小的时候每个人都喜欢但随着应用越来越大我们不得不面对的以下几个问题第一团队合作的效率越来越低这是无法避免的可能一个人的延期就会导致整个版本的延期而人越多这个概率就是指数级别的增长。第二潜在的bug越来越多功能越多隐藏的问题就自然就越多一旦爆发可能带来的影响会非常的大。第三应用越来越大导致新功能的开发越来越受到限制比如android的方法数65535的限制虚拟机内存的限制而且占用内存越大的应用在后台被回收的可能性也就越大等等。当然应用越来越大绝不仅仅只有这么点问题。我们这里列举的只是几个比较明显的问题。那这些问题该如何解决呢 这就需要提到我们文章的核心热修复与插件化技术了。
再讲热修复与插件化技术前呢大家首先要搞明白动态加载技术动态加载是安卓原生为我们提供的一种加载未安装到手机系统的apk文件或者jia包中的类这其中的核心技术就是对Classloader中的DexClassloader的合理的使用。这就为我们提供了一种思路既然我们可以加载未安装到android系统的一些特定格式文件中的class那我们能不能让应用在运行期动态的去加载这些文件中的类从而实现按我们的策略或者需求去加载我们想加载的类和资源呢。答案是肯定的解决方案就是我们的热修复与插件化技术的实践。其实热修复与插件化就是动态加载技术的不同的使用场景。下面我们就来分别介绍一下热修复与插件化技术。
热修复也叫动态更新从名字就可以很容易的理解它的作用就是用来动态的修改我们应用的缺陷的。以前我们在应用产生bug以后我们只能无奈的等待字啊一个版本的发布才能解决这个问题。但有了热修复技术以后那我们就无需等到下一个版本可以立马解决问题生成patch文件然后下发到用户手机让我们的应用去安装了这个patchpatch文件安装成功以后就可以替换掉我们有问题的代码从而达到问题的解决。经过15年的出现16年的发展到今天热修复技术已经已经比较成熟了比较有代表性的有alibaba的andfix和微信的tinker两种方案各有优劣andfix胜在patch文件可以立马生效而无需应用重启而tinker胜在不仅可以更新代码还可以更新资源文件技术没有绝对的好与不好适合自己的就是最好的。有了热修复技术以后基本上就可以解决应用越来越大带来的潜在问题越来越多的问题。在对热修复有了一定的了解后我们在来看插件化技术。
不同于热修复的容易理解插件化是一个不太容易被理解的概念那究竟什么是插件化呢插件化就是把一个大的应用拆分成多个小的应用这些小的应用相互配合实现和我们原来一个大应用完全一样的功能这个过程就叫插件化无论是手机淘宝还是优酷等应用无一不采用这一技术进行插件化改造而我也有幸参与了这个改造的过程整个流程下来我的感受是前期确实很繁琐各种修改重构解耦合组件化。但当整个过程都走完以后应用的结构变得非常的合理。各团队间的功能不在那么强耦合即使又耦合的地方也可以通过适当的技术去消除例如提取公共组件AIDL等。插件化以后我们每一个功能模块都是一个独立的小apk完全按照我们开发小应用的节奏一切又变的那么的简单。插件化技术比较成熟的是alibaba的Atlas和一个开源的框架small。二者又是各有千秋。Altas呢功能强大完整集合了插件化动态部署远程组件加载于一身但同时学习成本和改造成本也非常的大而small呢与它的名字一样专注于应用的插件化改造这一点让他的上手非常的容易如何选取技术方案就看大家的需求。两个技术方案都非常棒。
好说了这么多你对插件化与热修复应该有吧基本的认识了赶快学习起来吧。