版权声明

1.本文版权归原作者所有,转载需注明作者信息及原文出处。

2.本文作者:赵裕(vimerzhao),永久链接:https://github.com/vimerzhao/vimerzhao.github.io/blob/master/android/2020-02-11-apk-size-opt.md

3.作者公众号:V大师在一号线 。联系邮箱:vimerzhao@foxmail.com


背景

安装包膨胀的原因

业务的增加、产品的演进是安装包大小增加的本质原因。但是在演进之路上,由于一些所谓的技术债务,如:

  • 使用的资源未经裁剪(如全量字体文件、分辨率过大的图片)
  • 不合理的大资源(如大的视频、音频可以在线拉取)
  • 已下线业务没有及时清理相关代码、资源
  • 等等

正是由于这些疏忽,安装包有了不必要的增加,这也是我们需要优化的部分。

安装包优化的价值

可能有的人觉得,现在基本是4G、WiFi的网络环境,手机设备的性能和存储空间也非常充足,所以用户对安装包大小应该不是十分敏感。但是,这其实是一种错觉,更多的时候应该看自己的目标市场,如果是一二线城市当然没问题,但如果是三四线城市、农村等下沉市场或者印度、巴西等海外市场,上述假设显然不成立了。

一般来说,安装包大小会影响以下指标:

  • 下载转化率
  • 安装成功率
  • 推广成本
  • 运行内存、空间占用

综上,对于一个“有余力”的团队,安装包大小的优化还是很有必要的。

安装包优化的套路

由前面的原因可知,从业务层面来看,安装包大小的优化是“解铃还须系铃人”,即:

  • 压缩资源
  • 大资源转成在线拉取
  • 排查无用业务并下线

这些方法都比较常规,更像是对症下药,下面梳理一些技术上普适的方法,独立于业务,在上面那些方法都尝试后,还可以使安装包大小“更下一层楼”。

安装包的主要构成就是代码和资源,所以优化也是从这两个方面着手。

代码

混淆

一般是通过ProGuard,但很多用不好,且存在管理问题。最后一看项目,很多类被Keep住了,也不知道历史背景是啥。

Dex优化

  1. 通过工具移除行号信息,带来的问题是无法回溯Crash位置,但可以解决
  2. 多Dex时,通过重排Dex避免交叉索引,实现起来比较复杂
  3. Dex压缩,把实际的Dex压缩,首次启动通过一个壳去加载,会影响启动速度,但是可以解决,也比较复杂

so优化

so的优化手段和Java代码其实比较类似,核心还是通过机制化的手段去裁剪、压缩。

资源

资源本身

  • 通过工具扫描无用资源,有些由于项目自身原因,可能没有显式引用,但外置的编译脚本会修改项目自身脚本,这就很坑了
  • 资源格式的优化,如PNG转JPG(除去alpha通道),转webp格式等
  • 字体文件只保留使用的,资源自身的二次优化

资源索引

通过AndResGuard工具压缩资源名称,进而降低索引文件的大小。

感悟

核心思想

  • 删除不用的(显而易见)
  • 压缩/转移有用的(如图片、字体文件,如大资源的转移,混淆信息的map表也是一种转移)
  • 精简系统产生的(dex重排)

常规的手段很容易到达瓶颈,高深的手段又有复杂、兼容性等诸多问题,但综合来看,还是两点:

  • 深刻理解底层:apk编译流程、dex格式、资源引用、启动流程、加载流程原理等
  • 深刻理解工具:ProGuard(很多人的ProGuard配置都是Copy修改),ReDex,AndResGuard等

权衡之道

很多时候,优化就是权衡,重要的是取舍:

  • 压缩了Dex,就增加了启动速度
  • 拿掉了行号,就增加了恢复Crash堆栈的难度
  • 混淆了代码,就增加了编译脚本的复杂度
  • 等等

根本出路

  • 建立监控:团队每年都会优化一次安装包大小,尤其是删除、压缩资源的时候,总是一头雾水,不明白这个资源引入的目的,也不敢轻举妄动。最后有一套系统,让增量时有记录,让下线时有提醒,及时解决,而不是每到年底还一次技术债。
  • 制定标准:某种意义上上,安装包大小的优化不是某个人的事情,而是团队的事情,最好有相关的实践指南或CodeReview标准。当有人不合理地引入资源,又或者业务下线后对无效逻辑置之不顾时,能有规则来约束这种行为。

参考

以上


欢迎扫码关注作者公众号,及时获取最新信息。

技术|Android安装包优化的更多相关文章

  1. 技术|Android安装包极限优化

    版权声明 1.本文版权归原作者所有,转载需注明作者信息及原文出处. 2.本文作者:赵裕(vimerzhao),永久链接:https://github.com/vimerzhao/vimerzhao.g ...

  2. Android安装包相关知识汇总 (编译过程图给力)

    转自: https://mp.weixin.qq.com/s?__biz=MzAwNDY1ODY2OQ==&mid=208008519&idx=1&sn=278b7793699 ...

  3. android 安装包签名问题探究

    1.首先先科普一下,android为什么需要给安装包签名: 所有的Android应用程序在发布之前都要求开发人员用一个证书进行数字签名,anroid系统不会安装没有进行签名的由于程序.    平时我们 ...

  4. Android安装包apk文件在某些版本操作系统上安装解析包出错问题的解决办法

    当我们将Android升级功能的中的下载新版本apk文件存放在data/data/xxx.apk位置时,在有的些版本的手机中安装可能会出现安装包解析出错的问题,对于该问题的解决方案是提升该文件的权限. ...

  5. unity 导出 android安装包配置方案

    原地址:http://blog.csdn.net/u012085988/article/details/17393111 1.jdk本人安装的是win32版的(虽然系统是64位的.但听说装64位的导出 ...

  6. JFrame实现批量获取Android安装包安全证书MD5

    今天遇到一个需求.获取全部apk的签名的MD5.以下是我使用Java SE实现的一个工具.贴出核心源码.希望给有须要的朋友有所帮助. 界面例如以下: 仅仅须要制定.apk文件所在的文件夹就可以,核心代 ...

  7. 专项测试——移动app安装包检测

    一.背景和现状 安装包的重要性无需多提,针对安装包质量控制越来越严格和规范,包括证书.文件大小.安装成功率等,APP的证书及混淆是影响APP的安装成功率及代码安全性的很大因素,随着功能迭代,安装包也会 ...

  8. 减少iOS应用程序安装包大小

    安装包优化大小方法: <资源优化> 1.去除无用资源 通过几次项目的升级后,项目中会出现一些没有用到的图片.这些图片在我们导入到项目中后,之后项目升级过程后并没有再次用到. 那这些图片我们 ...

  9. 爱奇艺技术分享:爱奇艺Android客户端启动速度优化实践总结

    本文由爱奇艺技术团队原创分享,原题<爱奇艺Android客户端启动优化与分析>. 1.引言 互联网领域里有个八秒定律,如果网页打开时间超过8秒,便会有超过70%的用户放弃等待,对Andro ...

随机推荐

  1. Date、Time类型拼接成字符串

    Date.Time类型拼接成字符串 语言用的是kotlin,和Java类似 var time = "" val sdf1 = SimpleDateFormat("yyyy ...

  2. JavaScript-null与' '的区别

    null代表的是空对象无地址,而' '则代表的是有地址,但是这个地址里面的内容为空

  3. Sentinel :微服务哨兵

    1. Sentinel 是什么? 随着微服务的流行,服务和服务之间的稳定性变得越来越重要.Sentinel 以流量为切入点,从流量控制.熔断降级.系统负载保护等多个维度保护服务的稳定性. Sentin ...

  4. Scala与Mongodb实践2-----图片、日期的存储读取

    目的:在IDEA中实现图片.日期等相关的类型在mongodb存储读取 主要是Scala和mongodb里面的类型的转换.Scala里面的数据编码类型和mongodb里面的存储的数据类型各个不同.存在类 ...

  5. Flutter使用SingleTickerProviderStateMixin报错

    最近在学习开发Flutter应用项目,在创建tabbar和tabview后,进行网络请求后显示顶部tab标签,设置TabController,并使class类实现SingleTickerProvide ...

  6. 《C# 爬虫 破境之道》:第一境 爬虫原理 — 第一节:整体思路

    在构建本章节内容的时候,笔者也在想一个问题,究竟什么样的采集器框架,才能算得上是一个“全能”的呢?就我自己以往项目经历而言,可以归纳以下几个大的分类: 根据通讯协议:HTTP的.HTTPS的.TCP的 ...

  7. [bzoj4417] [洛谷P3990] [Shoi2013] 超级跳马

    Description 现有一个n行m列的棋盘,一只马欲从棋盘的左上角跳到右下角.每一步它向右跳奇数列,且跳到本行或相邻行.跳越期间,马不能离开棋盘.例如,当n = 3, m = 10时,下图是一种可 ...

  8. 频繁插入(insert)的业务,用什么存储引擎更合适? | 数据库系列(转)

    本文来自微信公众号 继续回答星球水友提问: 沈老师,MyISAM只支持表锁,但网上文章却说,在并发插入量比较大的时候,比较适合使用MyISAM,这矛盾吗? 这个问题,涉及MySQL表锁的一些细节,借着 ...

  9. python + selenium定位页面元素的办法

    1.什么是Selenium,为什么web测试,大家都用它? Selenium设计初衷就是为web项目的验收测试再开发.内核使用的是javaScript语言编写,几乎支持所以能运行javaScript的 ...

  10. linux 安装virtualbox5.2

    一.安装 1.下载package https://www.virtualbox.org/wiki/Linux_Downloads 2.添加源. $ cat /etc/lsb-release DISTR ...