91

应用模块化和懒加载在 Instagram 中的实现

 6 years ago
source link: https://zhuanlan.zhihu.com/p/30837815?
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

应用模块化和懒加载在 Instagram 中的实现

编程等 2 个话题下的优秀答主
简评:这是 Instagram Android 团队分享的 Android 应用模块化和懒加载经验,并且开源了他们的懒加载库,链接在文章结尾。: )

随着 Instagram 的规模和开发人员数量的不断增加,也导致了不少的问题:

  • App 体积增大;
  • 冷启动时间增加;
  • 所占存储空间增大;
  • 并且由于应用体积的增加导致构建时间的增长,减慢了开发人员的开发速度。

为了应对这些问题,Instagram 开始了应用的模块化工作,以求在不同功能间建立起清晰的边界。这里就是 Instagram 他们自己分享的如何做应用模块化和懒加载的。

应用模块化

什么是应用模块化?

模块化,顾名思义就是对代码根据业务逻辑进行分离和创建边界的过程。模块化的一个好处就是能优化应用的启动时间,在模块化之前,从一个功能到另一个功能的引用链可能会加载所有的代码,现在结合懒加载可以在需要的时候再加载模块。此外,对于构建时间,开发速度等等也有好处。

怎么模块化?

模块化关键的就是考量各个模块所具有的依赖关系。对于每个依赖关系,判断其是应该删除还是保留。虽然要具体情况具体分析,但也还是有一些共通的考虑事项:

  • 有没有办法将这个依赖重写为更通用的模块,而不是从特定业务模块中进行引用。
  • 这些依赖所实现的功能一定需要在现在引用吗?还是说可以推迟到执行具体业务逻辑时再引用。
  • 能否将逻辑简化到仅限于特定功能模块的范围内,以便更容易的判断依赖关系。

当完成了模块化后,该功能的界面就应该只会包含一些关键的方法,例如:

  • 生命周期相关的方法;
  • 导航到该功能模块的方法;

模块的懒加载

什么是懒加载?

延迟加载能够将原来一大块的 dex 文件根据功能编译为独立的 dex 文件,这能带来的好处:

  • 能够在真正需要某个功能时才加载到内存中,而不是在每次冷启动时加载。
  • 如果某些模块一直是未使用状态,这些代码也就不会被解压缩,因此所占用的磁盘空间也减少了。
  • 能让应用更方便的根据不同类型用户提供不同功能,缩小应用包的大小。

并且,针对开发效率而言,我们增加了对懒加载的热插拔支持,意味着开发人员能够在编码时马上看到变化,而无需重新启动应用。

什么时候触发懒加载?

一般来说,当我们预计一个模块在不久将来会使用时,就会对其加载。模块的加载因为不同的模块大小可能会有较小的延迟,因此需要采取不同的策略:

  • 如果用户可能通过点击触发这个功能模块时,就在后台预先加载模块。当然,用户是有可能不点击的,但如果这个模块的点击概率很高,那么这是一个合适的解决方案。
  • 在用户已经导航到该模块再进行加载。如果在测试中这个模块大多数时候加载延迟很小(小于 50ms),那么我们可以简单的直接等待加载完成。否则,可以显示一个进度条什么的,以便让应用不会被当成卡住了。
  • 还有些模块本身是异步的,比如视频的加载和播放。对于这样的模块,懒加载会将其加载到辅助进程。

Instagram 也开源了自己的懒加载库 - Instagram/ig-lazy-module-loader ,感兴趣的同学可以看看。

原文:App modularization and module lazy loading at Instagram and beyond

日报扩展阅读:


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK