<a href="http://blog.sina.com.cn/s/blog_7bee201901013nkk.html">http://blog.sina.com.cn/s/blog_7bee201901013nkk.html</a>
![](https://img.laitimes.com/img/_0nNw4CM6IyYiwiM6ICdiwiInBnauIDMkZ2N1QGMmRjMhNTO3UjNkdzMzUjY5ITO3MTYzQWYfdWbp9CXt92Yu4GZjlGbh5SZslmZxl3Lc9CX6MHc0RHaiojIsJye.jpg)
現在很多人想對Android工程的編譯和打包進行自動化,比如建立每日建構系統、自動生成釋出檔案等等。這些都需要我們對Android工程的編譯和打包有一個深入的了解,至少要知道它的每一步都做了什麼,需要什麼環境和工具,輸入和輸出是什麼。那麼我們就來挖掘一下Android的編譯過程中的細節。
首先,我們假定你的系統(什麼系統都行,不限于Linux還是Windows系統,當然,我在這裡預設使用Linux系統來舉例子,但在 Windows中幾乎沒有什麼差别)已經安裝了JDK和Android SDK。再假定你的Android SDK的路徑是ANDROID_SDK_HOME,你想要編譯的Android OS版本是ANDROID_OS_VERSION(比如android-1.6、android-8、android-10等)。
我們重點關心的是(1)這個過程的輸入是什麼?(2)這個過程的輸出是什麼?(3)這個過程使用了什麼工具?至于使用什麼參數,可以自己去看對應指令的幫助檔案,或者在網上搜尋,這不是本文的重點。
步驟中提到的工具如下表:
名稱
功能介紹
在作業系統中的路徑
aapt
Android資源打包工具
${ANDROID_SDK_HOME}/platform-tools/appt
aidl
Android接口描述語言轉化為.java檔案的工具
${ANDROID_SDK_HOME}/platform-tools/aidl
javac
Java Compiler
${JDK_HOME}/javac或/usr/bin/javac
dex
轉化.class檔案為Davik VM能識别的.dex檔案
${ANDROID_SDK_HOME}/platform-tools/dx
apkbuilder
生成apk包
${ANDROID_SDK_HOME}/tools/opkbuilder
jarsigner
.jar檔案的簽名工具
${JDK_HOME}/jarsigner或/usr/bin/jarsigner
zipalign
位元組碼對齊工具
${ANDROID_SDK_HOME}/tools/zipalign
第一步:打包資源檔案,生成R.java檔案
【輸入】Resource檔案(就是工程中res中的檔案)、Assets檔案(相當于另外一種資源,這種資源Android系統并不像對res中的檔案那樣優化它)、AndroidManifest.xml檔案(包名就是從這裡讀取的,因為生成R.java檔案需要包名)、Android基礎類庫(Android.jar檔案)
【輸出】打包好的資源(一般在Android工程的bin目錄可以看到一個叫resources.ap_的檔案就是它了)、R.java檔案(在gen目錄中,大家應該很熟悉了)
【工具】aapt工具,它的路徑在${ANDROID_SDK_HOME}/platform-tools/aapt(如果你使用的是Windows系統,按慣例路徑應該這樣寫:%ANDROID_SDK_HOME%\platform-tools\aapt.exe,下同)。
第二步:處理AIDL檔案,生成對應的.java檔案(當然,有很多工程沒有用到AIDL,那這個過程就可以省了)
【輸入】源碼檔案、aidl檔案、framework.aidl檔案
【輸出】對應的.java檔案
【工具】aidl工具
第三步:編譯Java檔案,生成對應的.class檔案
【輸入】源碼檔案(包括R.java和AIDL生成的.java檔案)、庫檔案(.jar檔案)
【輸出】.class檔案
【工具】javac工具
第四步:把.class檔案轉化成Davik VM支援的.dex檔案
【輸入】 .class檔案(包括Aidl生成.class檔案,R生成的.class檔案,源檔案生成的.class檔案),庫檔案(.jar檔案)
【輸出】.dex檔案
第五步:打包生成未簽名的.apk檔案
【輸入】打包後的資源檔案、打包後類檔案(.dex檔案)、libs檔案(包括.so檔案,當然很多工程都沒有這樣的檔案,如果你不使用C/C++開發的話)
【輸出】未簽名的.apk檔案
【工具】apkbuilder工具
第六步:對未簽名.apk檔案進行簽名
【輸入】未簽名的.apk檔案
【輸出】簽名的.apk檔案
【工具】jarsigner
第七步:對簽名後的.apk檔案進行對齊處理(不進行對齊處理是不能釋出到Google Market的)
【輸入】簽名後的.apk檔案
【輸出】對齊後的.apk檔案
【工具】zipalign工具
知道了這些細節之後,我們就可以實作很多我們想實作東西了,比如:自動化,我們可以使用某種腳本,像Windows下的批處理,linux下的Bash,Java下的Ant,Python、Perl這樣的腳本語言,甚至直接用Java、.net這們的強類型語言也是可以的。如果你真正弄懂了上面的步驟,了解了編譯打包過程的本質,你完全可以以你想要的任何方式實作它的自動化,這才是真正的“舉一反三,以不變應萬變”。再比如,對Android SDK的精簡,大家知道,現在Android SDK動轍幾百兆,我們完全可以應用上面的知識,隻保留必要的工具,把SDK精簡到10M以下。當然,還可以做很多事情,前提是你真正弄懂了它。