怎么将 Android 程序做成插件化的形式

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么将 Android 程序做成插件化的形式相关的知识,希望对你有一定的参考价值。

插件化技术发展到现在其实已经很成熟了,但是相应的问题,如果没有真正地去实践过,根本不了解其中有多少问题,会牵涉到多少技术细节,多少被外人膜拜的外表光鲜的技术大牛都被『插件化』这三个字折磨地死去活来,这对于 android 整个生态的损害也让人无法忽视。

我们首先要想一下,我们做插件化的目的是什么?
为了满足产品随时上线的需求?
为了修复因为我们对自己要求不严格而写出来的 bug ?
为了向人炫耀自己的技术实力?
很抱歉,如果是为了这些目的,那就真的太对不起自己是『开发者』这个如此高逼格的身份了。

做插件化真正的目的:是为了去适应并行开发,是为了解耦各个模块,是为了避免模块之间的交叉依赖,是为了加快编译速度,从而提高并行开发效率。

明确了这些,我们再来看插件化的结果,每个模块都支持独立运行测试,分为稳定的 release 版本和不稳定的 snapshot 版本,每个模块都高度解耦,没有交叉依赖,不会出现一个模块依赖了另一个模块,其中一个人改了这个模块的代码,对另一个模块造成影响。

按照这个思路,我们再来看看一些其他的细节:
在 Android 里有一个比较爽的一点是,作为 library 的时候,aar 里的引用依赖,在宿主 Application 里也有同样的引用依赖,并不会打包两份到宿主 Application 里;
模块之间的跳转,除了使用别名的方式,我能想到的还有另外一种方式,同样是通过 gradle 脚本,将跳转用到的类打成一个 jar ,作为一个 API 服务提供给其他模块作为编译期依赖(provided)引入;
各个 library 在 debug 的时候作为 apk ,要独立打包运行测试,这时就需要有一个启动 Activity ,而 library 是不需要的,我的想法是放置两个 AndroidManifest.xml ,使用 sourceSets 分别在 debug 和 release 的时候加载不同的 AndroidManifest.xml 。
参考技术A 前提你要会编程

以上是关于怎么将 Android 程序做成插件化的形式的主要内容,如果未能解决你的问题,请参考以下文章

怎么将 Android 程序做成插件化的形式

怎么将 Android 程序做成插件化的形式

怎么将 Android 程序做成插件化的形式

如何将Android程序做成插件化的形式?详解插件化实现原理

Android 插件化的 过去 现在 未来

Android 插件化多开原理 | 使用插件化技术的恶意应用 | 插件化的其它风险 | 应用开发推荐方案