最近和一个iOS同学说,我们Android apk build要比ios慢很多,他问我为什么要这么久,把我问懵了,不知道怎么解释。其实很多时候,你只要比别人多想一步就很厉害了。多问问自己为什么。
我们先看一张官方文档提供的apk构建流程图
![](https://img.haomeiwen.com/i10539841/b2038ba1dfed2547.png)
从上图可以看出来,构建的过程主要分为两步:
- 编译源码、资源以及第三方依赖库
- 签名、打包,生成apk
下面再来看另外一张图,详细分析了apk的构建过程以及构建过程中的工具
![](https://img.haomeiwen.com/i10539841/99dc28968a96810f.png)
流程概述:
- 打包资源文件,生成R.java文件
- 处理aidl文件,生成对应的java文件
- 编译工程源文件,生成相应的class文件
- 转换刚刚生成的class文件以及第三方依赖的class文件,生成dex文件
- 打包生成apk
- 对apk进行签名,生成签名之后的apk
- 对生成的apk进行优化,生成签名+优化后的apk
打包过程中需要的工具
aapt
Android资源打包工具,
目录:${ANDROID_SDK_HOME} /build-tools/ANDROID_VERSION/aapt
aidl
将aidl文件转成java文件
目录:${ANDROID_SDK_HOME}/build-tools/ ANDROID_VERSION/aidl
javac
不用解释了吧
目录:${JDK_HOME}
dex
将class文件转成Dalvik虚拟机能识别的dex文件
目录:${ANDROID_SDK_HOME}/build-tools/ ANDROID_VERSION/dx
apkbuilder
打包生成apk
这里需要注意下,就是这个工具已经在2014年就已经被移除了,在sdk的build-tools目录下根本就么有这个命令。现在打包生成apk用的是${ANDROID_SDK_HOME}/tools/lib/sdk-xxx.jar中的ApkBuilderMain类。
Jarsigner
签名工具,目录在${JDK_HOME}
zipaling
对apk进行优化减少其在设备上运行时的内存占用。
目录:${ANDROID_SDK_HOME}/build-tools/ ANDROID_VERSION/zipalign
构建流程详细分析
打包资源文件,生成R.java文件
这一步主要用的是aapt工具,打包的资源文件主要分为三部分,
- res目录,包括图片、xml等
- AndroidManifest.xml
- Assets文件
- Android.jar
上面这些资源文件中的xml(除了assets和raw目录)基本都会被编译成二进制的xml文件,这样空间更小。
经过aapt之后,主要生成两个文件,R.java文件以及resources.arsc文件。
R.java主要存放的是资源id,在我们公司的组件化过程中,为了防止插件和主站之间的资源id冲突,就是通过修改aapt源码来生成不同id,确保资源id不会冲突。
resources.arsc,存放了资源id与路径之间的映射关系。
关于资源打包的详细过程,可以参考老罗的博客https://blog.csdn.net/luoshengyang/article/details/8744683
这里插播一条res/raw和assets目录的区别
- 两个目录下的资源都直接拷贝到apk包中,不会编译成二级制文件
- raw目录下的文件会被映射到R.java文件中,可以通过R.id.xx来访问,而assets目录文件只能通过AssetManager来访问
- assets目录下可以创建目录,而raw目录不行
解析AIDL文件生成对应的java文件
使用aidl工具生成AIDL.java文件,这个很简单,应该就是通过一个模板文件了
java文件编译成class
使用javac工具来编译java文件为class文件了
编译后可对代码进行混淆处理,主要包括删除无用类、字节码优化、重命名等操作,只需在build.gradle中配置混淆规则即可
class转dex
这里主要使用dx来讲java字节码转成Dalvik字节码
打包apk
调用ApkBuilderMain这个java类来打包资源以及dex文件和so文件等
签名
对apk进行签名
优化并生成apk
使用zipalign来优化,具体怎么优化,可以参考https://developer.android.com/studio/command-line/zipalign
参考文章:
https://blog.csdn.net/jason0539/article/details/44917745
网友评论