Android Gradle 外掛程式 4.2.0 版 (2021 年 3 月)
相容性
最低版本 | 預設版本 | 備註 | |
---|---|---|---|
Gradle | 6.7.1 | 無 | 詳情請參閱「更新 Gradle」一節。 |
SDK Build Tools | 30.0.2 | 30.0.2 | 安裝或設定 SDK Build Tools。 |
NDK | 無 | 21.4.7075529 | 安裝或設定 NDK 其他版本。 |
新功能
此版本的 Android Gradle 外掛程式內附以下新功能。
預設使用 Java 語言 8 版本
從版本 4.2 開始,AGP 將預設使用 Java 8 語言層級。Java 8 可讓您存取一些較新的語言功能,包括 lambda 運算式、方法參照和靜態介面方法。如需完整的支援功能清單,請參閱 Java 8 說明文件。
如果想保留舊行為,請在模組層級 build.gradle.kts
或 build.gradle
檔案中明確指定 Java 7:
// build.gradle
android {
...
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_7
targetCompatibility JavaVersion.VERSION_1_7
}
// For Kotlin projects, compile to Java 6 instead of 7
kotlinOptions {
jvmTarget = "1.6"
}
}
// build.gradle.kts
android {
...
compileOptions {
sourceCompatibility = JavaVersion.VERSION_1_7
targetCompatibility = JavaVersion.VERSION_1_7
}
// For Kotlin projects, compile to Java 6 instead of 7
kotlinOptions {
jvmTarget = "1.6"
}
}
新 JVM 資源編譯器
Android Gradle 外掛程式 4.2 工具中的全新 JVM 資源編譯器取代了 AAPT2 資源編譯器的部分功能,這可能會讓建構效能提升,尤其是 Windows 電腦上的效能。系統會預設啟用新的 JVM 資源編譯器。
現已支援 v3 和 v4 簽署
Android Gradle 外掛程式 4.2 版現在支援 APK v3 和 APK v4 簽署格式。如要在建構作業中啟用其中一種格式,或同時啟用這兩種格式,請在模組層級 build.gradle
或 build.gradle.kts
檔案中加入下列屬性:
// build.gradle
android {
...
signingConfigs {
config {
...
enableV3Signing true
enableV4Signing true
}
}
}
// build.gradle.kts
android {
...
signingConfigs {
config {
...
enableV3Signing = true
enableV4Signing = true
}
}
}
APK v4 簽署可讓您在 Android 11 中使用 ADB 漸進式 APK 安裝快速部署大型 APK。這個新旗標會負責處理部署程序中的 APK 簽署步驟。
按照變化版本設定應用程式簽署
您現在可以在 Android Gradle 外掛程式中,依據變化版本啟用或停用應用程式簽署。
以下範例說明如何在 Kotlin 或 Groovy 中使用 onVariants()
方法,為每個變化版本設定應用程式簽署:
androidComponents {
onVariants(selector().withName("fooDebug"), {
signingConfig.enableV1Signing.set(false)
signingConfig.enableV2Signing.set(true)
})
新 Gradle 屬性:android.native.buildOutput
為減少建構輸出內容的雜亂情況,AGP 4.2 會篩選來自使用 CMake 和 ndk-build
的原生建構作業訊息,且預設只會顯示 C/C++ 編譯器輸出內容。在過去,系統會為建構的每個檔案產生一行輸出,進而產生大量資訊訊息。
如果您想查看完整的原生輸出內容,請將新的 Gradle 屬性 android.native.buildOutput
設為 verbose
。
您可以在 gradle.properties
檔案或指令列中設定這個屬性。
gradle.properties
android.native.buildOutput=verbose
指令列
-Pandroid.native.buildOutput=verbose
此屬性的預設值為 quiet
。
變更 gradle.properties 檔案行為
從 AGP 4.2 開始,您無法再覆寫子專案的 Gradle 屬性。換句話說,如果在子專案的 gradle.properties
檔案中宣告屬性 (而非根專案),系統會忽略該屬性。
例如,在先前的版本中,AGP 會讀取 <var>projectDir</var>/gradle.properties
、<var>projectDir</var>/app/gradle.properties
、<var>projectDir</var>/library/gradle.properties
等的值。針對應用程式模組,如果 <var>projectDir</var>/gradle.properties
和 <var>projectDir</var>/app/gradle.properties
中都存在相同的 Gradle 屬性,系統會優先採用 <var>projectDir</var>/app/gradle.properties
的值。
AGP 4.2 已變更此行為,AGP 也不會從子專案中的 gradle.properties
載入值 (例如:<var>projectDir</var>/app/gradle.properties
)。
這項變更反映了新的 Gradle 行為,並支援設定快取
如要進一步瞭解如何在 gradle.properties
檔案中設定值,請參閱 Gradle 文件。
Gradle 相容性與設定變更
在 Android Studio 中執行時,Gradle 建構工具會使用 Studio 隨附的 JDK。在先前的版本中,Studio 隨附的是 JDK 8。不過在 4.2 版中,隨附內容已改為 JDK 11。使用新的隨附 JDK 執行 Gradle 時,可能會因垃圾收集器的異動,導致產生不相容問題或影響 JVM 效能。這些問題說明如下。
注意:雖然我們建議透過 JDK 11 執行 Gradle,但您仍可在「Project Structure」對話方塊中變更用於執行 Gradle 的 JDK。變更這項設定只會變更執行 Gradle 所用的 JDK,不會變更用於執行 Studio 的 JDK。
Studio 與 Android Gradle 外掛程式 (AGP) 相容性
只要 AGP 執行的是 Gradle 4.8.1 以上版本,Android Studio 4.2 就能開啟使用 AGP 3.1 以上版本的專案。如要進一步瞭解 Gradle 相容性,請參閱「更新 Gradle」一文。
為 JDK 11 最佳化 Gradle 版本
這項 JDK 11 更新會影響 JVM 垃圾收集器的預設設定,因為 JDK 8 使用了平行垃圾收集器,而 JDK 11 則使用 G1 垃圾收集器。
為了提升建構效能,我們建議您使用平行垃圾收集器測試 Gradle 版本。在 gradle.properties
中設定以下內容:
org.gradle.jvmargs=-XX:+UseParallelGC
如果此欄位已設有其他選項,請新增選項:
org.gradle.jvmargs=-Xmx1536m -XX:+UseParallelGC
如要使用其他設定測量建構速度,請參閱「剖析建構作業」一文。
當 minSdk
= 28 以上時,APK 內的 DEX 檔案解壓縮
當 minSdk
= 28 以上時,AGP 現在預設會將未壓縮的 DEX 檔案封裝至 APK。這會增加 APK 大小,但會縮減裝置上的安裝大小,而且下載大小大致相同。
如要強制 AGP 封裝壓縮的 DEX 檔案,您可以在 build.gradle
檔案中加入以下內容:
android {
packagingOptions {
dex {
useLegacyPackaging true
}
}
}
使用 DSL 封裝壓縮的原生程式庫
我們建議您以未壓縮格式封裝原生程式庫,這樣可以縮減應用程式安裝大小、縮減應用程式下載大小,以及縮短使用者的應用程式載入時間。不過,如果您想在建構應用程式時,讓 Android Gradle 外掛程式封裝經過壓縮的原生資料庫,請在應用程式的 build.gradle
檔案中將 useLegacyPackaging
設為 true
:
android {
packagingOptions {
jniLibs {
useLegacyPackaging true
}
}
}
useLegacyPackaging
標記會取代資訊清單屬性 extractNativeLibs
。如需更多背景資訊,請參閱預設以未壓縮方式封裝的原生程式庫相關版本資訊。