Android优化打包apk体积那点事

最近这几年优化过不少体积包,都是根据项目优化瘦身的,因为各个项目不同,里面的资源也不一样,跟代码习惯也有关系,所以优化方法也有很多种。也没特殊整理过方法,今天整理一下优化apk的方法。我也去看了很多关于瘦身优化apk的文章,也借鉴了几个方法。但大多数都比较相同,这里我挑出了适合大多数项目的方法。

关于代码清理
在我们项目开发中,肯定有废弃的代码和资源,我们要及时地清理,来减小apk体积,下面给出几种清理的方法

检测无用的资源文件

image.png
image.png

要是比较相信自己的项目也可以直接

image.png
image.png

这个清理不一定全部清理干净,因为资源是经过反射或字符拼接等方式获取,所以检查不完全,需要不断的试验

在每个类的开发中,不泛有很多次的导入包,然后忘记清理

image.png

选中你要清理的模块然后清理,然后这个清理只是清理了未使用的导入包,所以在开发中的还需要注意未使用的对象、变量、方法等代码,要及时删除。

关于项目资源压缩

buildTypes {
    release {
            minifyEnabled true      // 开启混淆
            zipAlignEnabled true    // 已启用压缩
            shrinkResources true    // 缩减资源
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
    }
}

开启混淆,压缩资源,压缩代码

删除无用的语言资源

  android {
        defaultConfig {
            ...
//          resConfigs "zh"                // 保留中文支持
            resConfigs "en", 'zh-rCN'      // 国际化资源配置 减少无用资源打包进apk
        }
    }

如果是国内的项目,保留中文支持就可以了,下面国际化配置一般大多数项目都可以,保留了中文和英文,看项目需求

配置cpu架构
armeabi-v7a 或 armeabi 保留其一即可,如果开发中需要模拟器调试,就加上x86的架构,正式打包记得去掉,剩下的看项目需求配置

defaultConfig {
        ndk {
            abiFilters 'armeabi-v7a'
        }     
    }

图片资源优化
图片格式换成WebP,项目中图片越多,效果越明显;AS已经提供了一键切换

image.png

drawable shape绘制
能用代码解决的问题就不要用图片,能绘制的尽量用drawable,比如背景颜色、渐变,圆形、阴影等等。

移除无用的第三方库
引入之后未使用的,或者是功能下架之后未移除的。

功能重复的三方库整合
比如glide和picasso,都是图片库,保留其一即可。
比如BasePopup和XPopup,选择其一。

修改三方库的源码,不需要的代码剔除
引入一些功能很多的第三方库,实际你只用到了其中几项或者更少,其他都没有用到,但是打包还是会打包进去的,如果可以的话,把源码进行拷贝粘贴入项目,移除掉第三方库,这样还能减少编译的时间。

图片网络加载
图片资源占比还是比较大的,把图片上传到服务器,这样本地就减少了图片的资源,通过动态下载的方式减少包体积,当然有利就有弊,进行加载网络图片时,对网络环境、加载速度、用户流量等要求是必不可免的;

原生改用H5代码加载大图
有些功能原生实现成本比较大,比如促销活动、商品详情页面下方的长图等,这个时候H5是一种很好的替代方案。

以上操作适用于大多数项目,这一套组合拳下来,相信你的项目应该会缩减不少的体积。
但如果你说要想做到极致,当然还有一些骚操作:

图片着色器(针对同图不同色的处理)

R Field内联(内联R Field可以解决R Field过多导致MultiDex 65536的问题)

减少ENUM的使用(枚举)

去除debug信息与行号信息(如果不是极致不推荐) 可以参考支付宝的这篇 《支付宝 App 构建优化解析》Android 包大小极致压缩、等等。

这里就列出几个,相信肯定也还有一些骚操作,就不一一列举了,任何方法方式都只是为了优化,减少apk体积,选出适合项目本身的就好,如果为了优化导致项目不能运行,那就违背了初衷。

最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容

  • 在平??⒐讨?,随着应用功能不断增加和版本功能迭代,APK的体积大小在不知不觉中不断增大,而APK体积大小会影响...
    Kennor阅读 952评论 0 1
  • 1、svg的使用与优化2、Tint着色器的使用与优化3、资源打包配置优化4、动态库的打包配置优化5、移除无用的资源...
    南城的人阅读 790评论 0 0
  • 随着项目的不断迭代,功能越来越多,构建出来的apk文件的大小也会越来越大,这样会导致在移动网络情况下下载时,使用的...
    Androidgiao阅读 750评论 0 6
  • 前言 我司某产品产品从立项至今已经有三个年头,三年中的功能迭代导致项目中积累了大量过时的功能,把研发人员带到了业务...
    yi_zhe阅读 1,107评论 0 2
  • 面对那种无节操的产品,你们怎么办? 产品:“apk的体积是否可以优化以下,这样比较好推广!” 我:“不可以!” 产...
    笔墨Android阅读 1,660评论 0 8