Speedup:专为项目下Library project过多所设计的加速插件

An## 背景

随着app的持续迭代更新,新功能的持续集成等原因。项目中的library project越来越多。

特别是最近一两年来。流行起来了组件化,这更是直接增加了很多的本地library project的数量。导致每次需要打包apk运行时,都会需要对所有module都进行再次编译。严重影响打包速度。

加速插件简介

Speedup是一款专用于对多module环境下进行打包加速的gradle插件。主要依赖的基本原理有两个:

  1. 动态依赖替换
  2. 打包任务特性

插件地址

https://github.com/JumeiRdGroup/Speedup

动态依赖替换

我们先来看看常规多module环境下的打包流程:

从上图可以看到。每次打包的时候。都会经过以下几个步骤:

  1. 对依赖的module进行进行打包编译,生成各自library的aar依赖。
  2. 对aar依赖进行合并。包括classes.dex的合并、资源合并等。
  3. 将合并后的文件、资源进行打包,生成apk。

而如果。我们使用maven依赖的方式进行依赖的话。编译流程就会优化成下图所示的方式:

可以看到。与上面直接使用module依赖的方式相比:使用Maven仓库依赖的方式,由于maven仓库中提供的直接就是已打包好的aar依赖,所以直接干掉了module -> aar打包编译的过程,起到了加速编译的作用!

所以,现在我们就可以得出第一个结论:使用maven依赖比使用module依赖更快速!

所以这个时候。很多人的常规做法就是。想办法将这些module依赖的library,编译打包发布到各自的远程中央仓库中去,这样就能避免每次运行的时候都去进行额外编译,从而节省时间了。

但是这种做法存在几个问题:

  1. 绝大部分library并
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值