【Android高级工程师】APK构建原理由浅入深

如上图所示(方形:表示文件,菱形:表示操作):

1、 整个构建分为两个主要操作:编译(Compile)、打包(APK Package)

2、 编译 :编译器(Compiler)通过编译 源码 、AIDL文件 、资源文件 、依赖包,最终生成Dex文件和编译后的资源文件。

3、打包 :打包器(APK Packager)利用签名文件(KeyStore)和上一步编译过程中生成的Dex文件、编译后的资源文件打包成最终的APK文件。

再探构建

在上一步「初见构建」中,我们已经对APK打包的流程有了大致了解,接下来再详细一点。

方形:表示文件,椭圆:表示工具及操作)

上面这张图,显示了更为详细的构建流程。以虚线为界,前半部分描述了 编译流程 ,后半部分则描述了 打包流程

下面具体分析构建流,分为七步(其中编译1-4、打包5-7):

1、使用aapt工具,编译res/文件,生成编译后的二进制资源文件(.ap_文件)、R.java文件。(目前新版使用aapt2工具,R.java也替换成了R.jar)

2、使用aidl工具,根据aidl文件生成对应的Java接口文件

3、使用Java Compiler工具,Java Compiler(俗称javac)将R.java、项目中的代码、Aidl接口文件编译成.class文件。

4、使用dex工具,将上一步产生的.class文件和第三方依赖中的.class编译成.dex文件。(目前新版使用d8工具)

5、使用apkbuilder工具,将编译后的资源(.ap_文件)、dex文件及其他资源文件(例如:so文件、asset文件等),压缩成一个.apk文件。

6、使用Jarsigner工具,读取签名文件,对上一步中产生的apk文件进行签名,生成一个已签名的apk文件。

7、使用zipalign工具,对已签名的apk文件进行体积优化(只有v1签名才有这一步,v2签名的apk会在zipalign后签名被破坏)。

先休息3分钟,消化一下。

深入构建

准备深入构建流程,图片看似复杂,但是有看图技巧:

我们可以参照「再探构建」中所展示的图片来解读这张流程图。

以椭圆(工具及操作)为线索,按照之前说的构建流程来理解此图。aapt、aidl、javac、dex、apkbuilder Jarsigner、zipalign是不是很熟悉? 左边这一大块是关于Render Script、ndk编译的,我们暂时可以将其忽略(相信你读完本篇后不忽略的情况下,也可以自己分析了),只知道它提供.so文件和部分Java文件。

首先,看看左下角,椭圆操作分为三种:Gradle插件提供(由task完成)、Build工具提供、JDK自带

以aapt为例,深入分析更详细的构建流程:

在aapt之前,Gradle插件中的各类Merge类的Task会对Manifest、Res、Assets进行合并,这些被合并的资源可能来自于项目内部、android.jar、arr等第三方。这些合并后的文件作为输入文件,在经过appt编译后,编译后的资源文件、R.java文件,同时aapt也负责合并产生各类的混淆文件。

另外,在javac与dex操作之间多了一个proguard(混淆),proguard读取.class文件,生成混淆后的.class文件,交给dex(或d8)。

放弃构建

非常厉害,你对Android构建流程的了解已经超过了绝大部分的开发者(我猜的:-))。

不过离实践还差一点,想想当我们点击运行的时候gradle是怎么实现上述构建流程的? 当我们运行assembleRelease命令进行打包时,咦?这一串是啥玩意?对着上面分析的流程你就知道是啥玩意了。

解读版:

//以下两个task是预编译工作,暂不关心

Task :app:preBuild UP-TO-DATE
Task :app:preReleaseBuild UP-TO-DATE

//aidl编译

Task :app:compileReleaseAidl NO-SOURCE

//生成BuildConfig文件

Task :app:generateReleaseBuildConfig

//编译Renderscrip,暂不关心(感兴趣的可以去探究Renderscrip)

Task :app:compileReleaseRenderscript NO-SOURCE
//*
Task :app:javaPreCompileRelease

//生成资源文件并合并

Task :app:generateReleaseResValues
Task :app:generateReleaseResources
Task :app:createReleaseCompatibleScreenManifests
Task :app:extractDeepLinksRelease
Task :app:processReleaseManifest
Task :app:prepareLintJar UP-TO-DATE
Task :app:checkReleaseDuplicateClasses
Task :app:desugarReleaseFileDependencies
Task :app:mergeReleaseResources

//产生build/intermediates/compile_and_runtime_not_namespaced_r_class_jar/release/R.jar文件

Task :app:processReleaseResources

//javac将java编译成Class文件

Task :app:compileReleaseJavaWithJavac

//将资源文件编译并生成resource.arsc文件,并放入.ap_文件中(./app/build/intermediates/processed_res/release/out/resources-release.ap_)

Task :app:compileReleaseSources

Task :app:lintVitalRelease

//dex工具将.class文件编程传.dex文件

Task :app:dexBuilderRelease

//合并非res/的资源文件及assets文件

Task :app:mergeExtDexRelease
Task :app:mergeReleaseShaders
Task :app:compileReleaseShaders NO-SOURCE
Task :app:generateReleaseAssets UP-TO-DATE
Task :app:mergeReleaseAssets
Task :app:processReleaseJavaRes NO-SOURCE
Task :app:collectReleaseDependencies
Task :app:sdkReleaseDependencyData
Task :app:mergeReleaseJniLibFolders
Task :app:mergeReleaseNativeLibs
Task :app:stripReleaseDebugSymbols NO-SOURCE
Task :app:mergeReleaseJavaResource

//合并.dex文件

Task :app:mergeDexRelease

//将.dex文件、.ap_打包进以及非res资源文件打包进.apk文件中并签名

Task :app:packageRelease

使用zipalign对apk进行体积优化

Task :app:assembleRelease
复制代码

说好的「放弃构建」,怎么还没放弃呢?了解到构建流程后,现在 放弃 自动构建apk,使用手动构建apk。步骤如下:

1、编译项目中的res资源文件(assets除外),生成对应二进制资源文件,并将这些二进制文件打包进res.zip文件中

$aapt2 compile -o build/res.zip --dir ./app/src/main/res
复制代码

2、将res.zip文件与sdk进行连接,生成.ap_文件(包含编译好的资源文件、manifest文件、arsc文件)和R.java文件,

$aapt2 link build/res.zip -I $ANDROID_HOME/platforms/android-21/android.jar --java build --manifest ./app/src/main/AndroidManifest.xml -o build/app-debug.ap_
复制代码

3、将java文件编译成.class文件

$javac -d build -cp $ANDROID_HOME/platforms/android-21/android.jar com/*/.java
复制代码
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

总之啊,家里没矿的同学们,如果你们想以后的日子过得好一些,多想想你们的业余时间怎么安排吧;

技术方面的提升肯定是重中之重,但是技术外的一些“软实力”也不能完全忽视,很多时候升职确实是因为你的技术足够强,但也与你的“软实力”密切相关

在这我也分享一份大佬自己收录整理的 Android学习PDF+架构视频+面试文档+源码笔记 ,还有高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料这些都是我闲暇还会反复翻阅并给下属员工学习的精品资料。在脑图中,每个知识点专题都配有相对应的实战项目,可以有效的帮助大家掌握知识点。

总之也是在这里帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习

相信自己,没有做不到的,只有想不到的

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

Gry-1712310553766)]

[外链图片转存中…(img-g8YzmUvW-1712310553766)]

相信自己,没有做不到的,只有想不到的

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
  • 28
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值