APK打包安装流程

APK打包安装流程

http://cdn.wutongliran.top/img/APK%E6%89%93%E5%8C%85%E6%B5%81%E7%A8%8B.png

打包资源的工具是aapt(The Android Asset Packaing Tool)

在这个过程中,项目中的AndroidManifest.xml文件和布局文件XML都会编译,然后生成相应的R.java,另外AndroidManifest.xml会被aapt编译成二进制。

存放在APP的res目录下的资源,该类资源在APP打包前大多会被编译,变成二进制文件,并会为每个该类文件赋予一个resource id。对于该类资源的访问,应用层代码则是通过resource id进行访问的。Android应用在编译过程中aapt工具会对资源文件进行编译,并生成一个resource.arsc文件,resource.arsc文件相当于一个文件索引表,记录了很多跟资源相关的信息。

这一过程中使用到的工具是aidl(Android Interface Definition Language),即Android接口描述语言。

aidl工具解析接口定义文件然后生成相应的.Java代码接口供程序调用。

如果在项目没有使用到aidl文件,则可以跳过这一步。

项目中所有的.Java代码,包括R.java和*.aidl文件,都会变Java编译器(javac)编译成.class*文件,生成的class文件位于工程中的bin/classes目录下。

dx工具生成可供Android系统Dalvik虚拟机执行的classes.dex文件。

任何第三方的libraries和*.class文件都会被转换成.dex*文件。

dx工具的主要工作是将Java字节码转成成Dalvik字节码、压缩常量池、消除冗余信息等。

所有没有编译的资源,如images、assets目录下资源(该类文件是一些原始文件,APP打包时并不会对其进行编译,而是直接打包到APP中,对于这一类资源文件的访问,应用层代码需要通过文件名对其进行访问);

编译过的资源和*.dex文件都会被apkbuilder工具打包到最终的.apk*文件中。

打包的工具apkbuilder位于 android-sdk/tools目录下。

一旦APK文件生成,它必须被签名才能被安装在设备上。

在开发过程中,主要用到的就是两种签名的keystore。一种是用于调试的debug.keystore,它主要用于调试,在Eclipse或者Android Studio中直接run以后跑在手机上的就是使用的debug.keystore。

另一种就是用于发布正式版本的keystore。

如果你发布的apk是正式版的话,就必须对APK进行对齐处理,用到的工具是zipalign。

对齐的主要过程是将APK包中所有的资源文件距离文件起始偏移为4字节整数倍,这样通过内存映射访问apk文件时的速度会更快。对齐的作用就是减少运行时内存的使用。

APK安装涉及到以下几个目录:

  • system/app:系统自带的应用程序,获得adb root权限才能删除
  • data/app:用户程序安装的目录,安装时把apk文件复制到此目录
  • data/data:存放应用程序的数据
  • data/dalvik-cache:将apk中的dex文件安装到dalvik-cache目录下(dex文件是dalvik虚拟机的可执行文件,其大小原为原始apk文件大小的四分之一)

安装过程:

复制apk安装包到data/data目录下,解压并扫描安装包,把dex文件(dalvik字节码)保存到data/dalvik-cache目录,并在data/data目录下创建对应应用数据目录

卸载过程:

删除安装过程中在上述三个目录下创建的文件目录


  1. 原文出自:https://zhuanlan.zhihu.com/p/348198783 ↩︎