Android Consumer SDK v2.0.0 迁移

Gradle 和 Android Gradle 插件更新

升级 Gradle 和 Android Gradle 插件版本

首先,升级 Gradle 和 Android Gradle 插件版本。此次升级改进了与某些 SDK 依赖项(包括 Kotlin 1.9)的兼容性,并修复了一些重大问题。

此 SDK 主要版本需要您的 Android 应用项目的以下版本依赖项:

  • Gradle 版本至少为 v7.5.0,但不高于 v7.6.0。
  • v7.4.x 范围内的 Android Gradle 插件 (AGP) 版本。

您可以以更高版本的插件为目标平台;但是,您可能会遇到弃用警告,或者某些新功能可能无法正常运行。

如需修改 Gradle 版本,请修改项目的 /gradle/wrapper/gradle-wrapper.properties 文件中的行

distributionUrl=https\://services.gradle.org/distributions/gradle-7.5.1-all.zip

如需修改 Android Gradle 插件版本,请修改包含 buildscript 代码块的 build.gradle 文件。例如:

buildscript {
    repositories {
        google()
        mavenCentral()
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:7.4.1'
    }
}

从 Java 7 到 Java 8 库支持迁移

第 1 步 - 启用 Java 8 库支持

来源

由于 SDK 最低 API 级别为 23,而所需的 AGP 版本为 7.4 及更高版本,因此配置与上述源代码文档略有不同。

buildscript {

    repositories {
        google()
        mavenCentral()
        jcenter()
        maven {
            url = uri("https://storage.googleapis.com/r8-releases/raw")
        }
    }
    dependencies {
        classpath 'com.android.tools:r8:8.0.46'
        classpath 'com.android.tools.build:gradle:7.4.1'
    }
}

android {
    compileOptions {
        // Flag to enable support for the new language APIs
        coreLibraryDesugaringEnabled true
        // Sets Java compatibility to Java 8
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }
}

dependencies {
    coreLibraryDesugaring 'com.android.tools:desugar_jdk_libs_nio:2.0.3'
}

第 2 步 - 从 Proguard 或 Dexguard 迁移到 R8

R8,源代码

AGP v7.4 及更高版本使用 R8 作为二进制文件的默认缩减、混淆处理和优化工具,因此此时无需执行任何特殊操作。

如果项目是从 AGP 4.0 及更高版本迁移,AGP 可能会发出以下有关文件移除的警告:

  • build.gradle 文件中的“useProguard true”使用情况
  • gradle.properties 文件中的“android.enableR8=false”使用情况

移除这些行通常可以解决这些问题。

从 Kotlin 1.6 迁移到 1.9

第 1 步 - 迁移到 Kotlin Gradle 插件 1.9.0

来源

更新应用顶级模块 build.gradle 文件中的 Kotlin Gradle 插件版本。请务必在 buildscript 代码块的依赖项中添加 org.jetbrains.kotlin:kotlin-gradle-plugin,以防依赖项缺失。

buildscript {
  dependencies {
    classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.9.0"
  }
}

如果您的应用来自 Kotlin Gradle 插件 1.6.X 或 1.7.X,则必须从 Kotlin 合成迁移应用。如需了解详情,请参阅官方迁移指南

第 2 步 - 将 kotlin-stdlib 升级到 1.9.0

来源

在应用 build.gradle 文件中将 kotlin-stblib 升级到 1.9.0。

dependencies {
    implementation "org.jetbrains.kotlin:kotlin-stdlib:1.9.0"
}

请务必移除对 kotlin-stdlib-jdk7kotlin-stdlib-jdk8 的任何引用。从 Kotlin 1.8.0 开始,这两个依赖项已合并到 kotlin-stdlib 中。