Android Gradle 外掛程式 4.2.0 版 (2021 年 3 月)
相容性
最低版本 | 預設版本 | 附註 | |
---|---|---|---|
Gradle | 6.7.1 | 無 | 詳情請參閱「更新 Gradle」一節。 |
SDK 版本工具 | 30.0.2 | 30.0.2 | 安裝或設定 SDK 版本工具。 |
NDK | 不適用 | 21.4.7075529 | 安裝或設定 NDK 其他版本。 |
新功能
此版本的 Android Gradle 外掛程式內附以下新功能。
預設使用 Java 語言 8 版本
從 4.2 版本開始,AGP 將預設使用 Java 8 語言層級。Java 8 提供幾種較新的語言功能,包括 lambda 運算式、方法參照和靜態介面方法。完整清單 請參閱 Java 8 說明文件。
如要保留舊行為,請在模組層級中明確指定 Java 7
build.gradle.kts
或 build.gradle
檔案:
// 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 簽署可讓您使用 ADB 快速部署大型 APK APK 逐步安裝 Android 11。這個新旗標會負責處理部署程序中的 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)
Android Studio 4.2 可以開啟使用 AGP 3.1 和 前提是 AGP 執行 Gradle 4.8.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 大小增加,但會導致
而且下載大小大致相同。
若要強制 AGP 封裝壓縮的 DEX 檔案,您可以在 build.gradle
檔案中加入以下內容:
android {
packagingOptions {
dex {
useLegacyPackaging true
}
}
}
使用 DSL 封裝壓縮的原生程式庫
我們建議以未壓縮格式封裝原生資料庫
不僅能縮減應用程式安裝大小、縮減應用程式下載大小,以及加快應用程式下載速度
縮短使用者載入時間不過,如果您想在建構應用程式時,讓 Android Gradle 外掛程式封裝經過壓縮的原生程式庫,請在應用程式的 build.gradle
檔案中將 useLegacyPackaging
設為 true
:
android {
packagingOptions {
jniLibs {
useLegacyPackaging true
}
}
}
旗標 useLegacyPackaging
會取代資訊清單屬性 extractNativeLibs
。如需更多背景資訊,請參閱版本資訊
預設以未壓縮方式封裝原生資料庫。