Android Studio 和 Android Gradle 插件的已知问题

本页记录了 Android Studio Chipmunk | 2021.2.1 和 Android Gradle 插件 7.2.2 的已知问题。如果您遇到本页尚未提及的问题,请报告 bug

升级到预览版:我们发布每个版本的 Android Studio 和 Android Gradle 插件都是为了提高稳定性和性能以及增加一些新功能。如需立即体验即将推出的版本的优势,请下载并安装 Android Studio 预览版

Android Studio 的已知问题

本部分将介绍最新的稳定版 Android Studio 中存在的已知问题。

渲染 Compose 预览时出错

从 Android Studio Chipmunk 开始,如果您在问题面板中看到 java.lang.NoSuchFieldError: view_tree_saved_state_registry_ownerjava.lang.ClassNotFoundException: androidx.savedstate.R$id,请务必在模块中添加对 androidx.lifecycle:lifecycle-viewmodel-savedstatedebugImplementation 依赖项。

如果您在问题面板中看到 java.lang.NoSuchFieldError: view_tree_lifecycle_owner,请务必在模块中添加对 androidx.lifecycle:lifecycle-runtimedebugImplementation 依赖项。

如果您在问题面板中看到 java.lang.NoClassDefFoundError: Could not initialize class androidx.customview.poolingcontainer.PoolingContainerjava.lang.NoClassDefFoundError: androidx/customview/poolingcontainer/PoolingContainerListener,请务必在模块中添加对 androidx.customview:customview-poolingcontainerdebugImplementation 依赖项。

对密钥和密钥库使用不同的密码时出错

从 4.2 版本开始,Android Studio 现在将在 JDK 11 上运行。此变更会导致与签名密钥相关的底层行为发生变更。

在您依次进入 Build > Generate Signed Bundle / APK 并尝试为 app bundle 或 APK 配置应用签名时,如果对密钥和密钥库输入不同的密码,就可能会导致以下错误:

Key was created with errors:
Warning: Different store and Key passwords not supported for PKCS12 Key stores

如需解决此问题,请为密钥和密钥库输入相同的密码。

安装 4.2 版本后,Android Studio 无法启动

Studio 会尝试导入之前版本的 .vmoptions 并对其进行清理,以便与 JDK 11 使用的垃圾回收器配合使用。如果此进程失败,对于在 .vmoptions 文件中设置了自定义虚拟机选项的用户,Android Studio 可能不会启动。

为了解决此问题,我们建议在 .vmoptions 中注释掉自定义选项(使用“#”字符)。.vmoptions 文件位于以下位置:

Windows

C:\Users\YourUserName\AppData\[Local|Roaming]\Google\AndroidStudio4.2\studio64.exe.vmoptions

macOS

~/Library/Application Support/Google/AndroidStudio4.2/studio.vmoptions

Linux

~/.config/Google/AndroidStudio4.2/studio64.vmoptions

如果尝试过此权宜解决方法后 Studio 仍未启动,请参阅下面的 Studio 在升级后没有启动

使用 Database Inspector 的应用在 Android 11 模拟器上发生崩溃问题

使用 Database Inspector 的应用在 Android 11 模拟器上运行时可能会崩溃;如发生崩溃,logcat 中会显示如下错误:

 Fatal signal 11 (SIGSEGV), code 1 (SEGV_MAPERR)

要想解决此问题,请将 Android 11 模拟器升级到版本 9 或更高版本,方法如下:依次转到 Tools > SDK Manager,在 SDK Platforms 标签页中,选中标签为 Show Package Details 的复选框,然后选择 Android 11 模拟器修订版 9 或更高版本。

Studio 在升级后没有启动

如果 Studio 在升级后没有启动,可能是因为从旧版 Android Studio 导入的 Android Studio 配置无效或插件不兼容。为了解决此问题,请根据所使用的 Android Studio 版本和操作系统,尝试删除以下目录(或重命名以下目录,以作备份),然后再次启动 Android Studio。这会将 Android Studio 重置为其默认状态,并移除所有第三方插件。

对于 Android Studio 4.1 及更高版本:

  • Windows%APPDATA%\Google\AndroidStudio<version>
    示例:C:\Users\your_user_name\AppData\Roaming\Google\AndroidStudio4.1

  • macOS~/Library/Application Support/Google/AndroidStudio<version>
    示例:~/Library/Application Support/Google/AndroidStudio4.1

  • Linux~/.config/Google/AndroidStudio<version>~/.local/share/Google/AndroidStudio<version>
    示例:~/.config/Google/AndroidStudio4.1~/.local/share/Google/AndroidStudio4.1

对于 Android Studio 4.0 及更低版本:

  • Windows%HOMEPATH%\.AndroidStudio<version>\config
    示例:C:\Users\your_user_name\.AndroidStudio3.6\config

  • macOS~/Library/Preferences/AndroidStudio<version>
    示例:~/Library/Preferences/AndroidStudio3.6

  • Linux~/.AndroidStudio<version>/config
    示例:~/.AndroidStudio3.6/config

请注意,Android Studio Canary 版和 Beta 版的配置目录是 PreviewX.Y(而不是用于 <version>X.Y)。例如,Android Studio 4.1 Canary build 使用的是 AndroidStudioPreview4.1 目录,而不是 AndroidStudio4.1 目录,后者用于候选版本和稳定版本。

Kotlin 多平台项目中的编译问题

Kotlin MPP 代码中可能会因缺少符号而出现编译错误。将 Kotlin 插件升级到版本 1.4 应该能解决此问题。

Linux 上的按键映射冲突

在 Linux 上,某些键盘快捷键会与默认的 Linux 键盘快捷键以及常见窗口管理器(例如 KDE 和 GNOME)的键盘快捷键冲突。这些冲突的键盘快捷键可能无法在 Android Studio 中正常使用。

如需详细了解此问题(包括可能的解决办法),请参阅 IntelliJ 的错误跟踪器

Chrome 操作系统上的界面文字太小

在 Chrome 操作系统上,文字看起来可能比以前版本中的文字小得多。若要解决此问题,请执行以下操作:

  1. 依次点击 File > Settings,打开 Settings 窗口
  2. 依次转到 Appearance & Behavior > Appearance
  3. 选择 Use custom font
  4. 增大字号。
  5. Settings 窗口中,依次转到 Editor > Font
  6. 增大字号。
  7. 点击 OK

代码编辑

本部分将说明与代码编辑器相关的已知问题。

键盘输入冻结 - Linux 上的“iBus”问题

Linux 上的 iBus 守护程序与 Android Studio 之间存在一些已知的互动问题。在某些情况下,IDE 会停止响应键盘输入或开始输入随机字符。此错误由 iBus 和 XLib + AWT 之间的同步不完整而引发,并且已报告给上游的 JetBrainsiBus 开发者。此问题目前有三种解决方法:

  • 解决方法 1:强制 iBus 进入同步模式。在启动 Android Studio 之前,请在命令行中运行以下命令:
    $ IBUS_ENABLE_SYNC_MODE=1 ibus-daemon -xrd
  • 解决方法 2:在 Android Studio 中停用 iBus 输入法。如需仅对 Android Studio 停用 iBus 输入法,请在命令行中运行以下命令:
    $ XMODIFIERS= ./bin/studio.sh
    这样做只会对 Android Studio 停用输入法,而不会影响您可能正在运行的任何其他应用。请注意,如果您在 Android Studio 处于运行状态时重启 iBus 守护程序(例如,通过运行 ibus-daemon -rd),则相当于对所有其他应用停用了输入法,并可能导致 Android Studio 的 JVM 崩溃以及出现分段错误。
  • 解决方法 3:仔细检查快捷键设置,确保未将 Next input shortcut 设置为 Ctrl+Space,因为这也是 Android Studio 中的代码补全快捷键。Ubuntu 14.04 (Trusty) 中的默认快捷键是 Super+Space,但也可能沿用了先前版本的设置。如需检查快捷键设置,请在命令行中运行 ibus-setup 以打开“IBus Preferences”窗口。在 Keyboard Shortcuts 下,选中 Next input method。如果它已被设为 Ctrl+Space,请将其更改为 Super+Space 或您选择的其他快捷键。

项目配置

本部分将介绍与项目配置和 Gradle 同步相关的已知问题。

Gradle 同步失败:管道无效

此问题是因 Gradle 守护程序尝试使用 IPv4 而非 IPv6 引起的。

  • 解决方法 1:在 Linux 上,将以下内容放入 ~/.profile~/.bash_profile 中:
    export _JAVA_OPTIONS="-Djava.net.preferIPv6Addresses=true"
  • 解决方法 2:在 Android Studio 的 vmoptions 文件中,将 -Djava.net.preferIPv4Addresses=true 行更改为 -Djava.net.preferIPv6Addresses=true。如需了解详情,请参阅网络 IPv6 用户指南

Gradle 同步或 SDK 管理器发生“peer not authenticated”错误

这些错误的根本原因在于 $JAVA_HOME/jre/lib/certificates/cacerts 中缺少证书。如需解决此类错误,请按以下步骤操作:

  • 如果您使用了网络代理,请尝试直接连接。如果直接连接有效,那么为了通过代理进行连接,您可能需要使用 keytool 将代理服务器的证书添加到 cacerts 文件中。
  • 重新安装受支持且未经修改的 JDK。存在一个影响 Ubuntu 用户的已知问题,会产生空的 /etc/ssl/certs/java/cacerts。如需解决此问题,请在命令行中执行以下命令:
    sudo /var/lib/dpkg/info/ca-certificates-java.postinst configure

部署

本部分将介绍有关将应用部署到已连接设备的已知问题。

[仅限 Mac OS] 由于保存在 /System/Volumes/Data 下的项目的 Gradle 文件监控存在问题,因此系统无法应用增量更新

Gradle 问题 18149 会影响 Android Gradle 插件版本 7.0 及更高版本,因为它们需要 Gradle 版本 7.0 及更高版本。从 Gradle 7.0 开始,文件监控功能默认处于启用状态。如果您使用的是 Mac OS 并且项目保存在 /System/Volumes/Data 下,Gradle 文件监控功能将无法正确跟踪文件更改。这会使构建系统看不到任何文件更改,因此无法更新 APK。此时,增量部署代码将不执行任何操作,因为本地 APK 状态与设备上的状态相同。

如需解决此问题,您应将项目的目录移动到用户目录,即 /Users/username 下。然后,构建系统会通过 Gradle 文件监控功能正确收到有关文件更改的通知,并成功应用增量更改。

macOS High Sierra 上的 Android 模拟器 HAXM

macOS High Sierra (10.13) 上的 Android 模拟器需要 HAXM 6.2.1+ 才能实现最佳的 macOS 兼容性和稳定性。不过,在 macOS 10.13 上安装 HAXM 等内核扩展的流程更为繁琐。您需要按以下方式手动允许安装内核扩展:

  1. 首先,尝试通过 SDK 管理器安装最新版本的 HAXM。
  2. 在 MacOS 中,依次转到 System Preferences > Security and Privacy
  3. 如果您看到“System software from developer "Intel Corporation Apps" was blocked from loading”,请点击 Allow

如需了解详情和解决方法,请参阅此 Apple 网页问题 62395878

Apply Changes

本部分介绍与 Apply Changes 相关的已知问题。

未应用新的应用名称

如果您重命名应用,然后尝试应用此更改,系统可能不会显示更新后的名称。若要解决此问题,请点击 Run 图标 “Run”图标 重新部署应用,然后您就会看到相应更改。

Android Runtime 中的问题抛出错误

如果您使用的是搭载 Android 8.0 或 8.1 的设备,那么在尝试应用某些类型的更改时(特别是当您使用 Kotlin 时),您可能会看到“VERIFICATION_ERROR”消息。此消息是由 Android Runtime 相关问题引起的,该问题在 Android 9.0 及更高版本中已解决。虽然该问题会导致 Apply Changes 失败,但您仍可通过点击 Run 图标 “Run”图标 重新运行应用来查看更改。不过,仍建议您将设备升级到 Android 9.0 或更高版本。

调试和测试

本部分将介绍与调试和测试应用相关的已知问题。

从 Android Studio 运行时,JUnit 测试在类路径中找不到资源

如果您的 Java 模块使用了特定的资源文件夹,那么从 IDE 运行测试时将找不到这些资源。您可以从命令行使用 Gradle 运行测试,也可以从 IDE 执行 Gradle check 任务。如需了解详情,请参阅问题 64887

出现此问题的原因是,从 IntelliJ 13 起,您只能将一个文件夹用作类路径。IntelliJ 的构建工具会将所有资源复制到该 build 文件夹中,但 Gradle 不会复制这些资源。

  • 解决方法 1:从 IDE 运行 Gradle check 任务,而不是运行单元测试。
  • 解决方法 2:更新构建脚本以手动将资源复制到 build 文件夹中。如需了解详情,请参阅此处的第 13 条评论

运行 JUnit 测试可能会编译两次代码

创建新项目时,系统可能会在 Make 和 Gradle-aware Make 这两个“发布前”步骤中创建模板 JUnit 配置。然后,系统会将此配置传播到所有已创建的 JUnit 运行配置。

  • 若要为当前项目修复此问题,请依次点击 Run > Edit Configurations,然后将默认的 JUnit 配置更改为仅包含 Gradle-aware Make 步骤。
  • 若要为今后的所有项目解决此问题,请依次点击 File > Close Project。您应该会看到欢迎屏幕。然后,依次点击 Configure > Project Defaults > Run Configurations,并将 JUnit 配置更改为仅包含 Gradle-aware Make 步骤。

某些测试运行配置无效

右键点击某个测试方法时,并非所有可用的运行配置都有效。具体而言,以下配置无效:

  • Gradle 运行配置(其图标为 Gradle 徽标)无效。
  • JUnit 运行配置(其图标不带绿色的 Android)不适用于插桩测试(此类测试无法在本地 JVM 上运行)。
Android Studio 还会记住在给定上下文中创建的运行配置(例如,右键点击特定类或方法),并且以后不会为您提供在其他配置中运行的选项。若要修复此问题,请依次点击 Run > Edit Configurations,然后移除错误创建的配置。

调试原生代码时添加 Java 断点

当您的应用在原生代码中的断点处暂停时,AutoDual 调试程序可能无法立即识别您设置的新 Java 断点。若要避免此问题,请在启动调试会话之前或在 Java 断点处暂停应用时添加 Java 断点。如需了解详情,请参阅问题 229949

退出原生调试程序

使用 AutoDual 调试程序调试 Java 代码和原生代码时,如果您通过 Java 代码逐步执行原生函数(例如,调试程序在调用原生函数的某行 Java 代码处暂停执行,并且您点击 Step Into 图标 )并且希望返回到 Java 代码,请点击 Resume Program 图标 (而非 Step Out 图标 Step Over 图标 )。您的应用进程仍将处于暂停状态,因此请点击 your-module-java 标签页中的 Resume Program 图标 来将其恢复。如需了解详情,请参阅问题 224385

原生调试程序在加载库时挂起

在升级到 Android Studio 4.2 及更高版本后首次使用原生调试程序时,原生调试程序可能会在从 Android 设备加载库时停止响应。这是一项棘手的问题,即使您停止并重启调试程序,也会继续出现此问题。如需解决此问题,请在 $USER/.lldb/module-cache/ 删除 LLDB 缓存。

原生调试程序崩溃并显示“Debugger process finished with exit code 127”

基于 Linux 的平台在启动原生调试程序时会发生此错误。这表示原生调试程序所需的某个库未安装在本地系统上。缺少的库的名称可能已输出到 idea.log 文件中。若未输出,您可以使用终端进入 Android Studio 安装目录,然后执行 bin/lldb/bin/LLDBFrontend --version 命令行以查明缺少哪些库。通常,缺少的库是 ncurses5,因为某些最新的 Linux 发行版已升级到 ncurses6

性能分析器

本部分将说明性能分析器的已知问题。

原生内存分析器:在应用启动过程中无法进行性能分析

原生内存分析器目前在应用启动过程中不可用。此选项会在即将发布的版本中提供。

解决方法之一是,您可以使用 Perfetto 独立命令行性能分析器捕获启动配置文件。

CPU 性能剖析器中的超时错误

如果您选择采样 Java 方法跟踪 Java 方法配置,则可能会在 Android Studio CPU 性能剖析器中遇到“停止记录失败”错误。这些是常见的超时错误,尤其是当您在 idea.log 文件中看到以下错误消息时:

Wait for ART trace file timed out

超时错误对所跟踪方法的影响往往大于所采样方法,对较长时间记录的影响往往大于较短时间的记录。作为临时解决方法,尝试较短时间的记录以查看错误是否消失可能会很有帮助。

如果您在使用性能分析器时遇到超时问题,请提交 bug,在提交内容中附上设备品牌/型号以及来自 idea.log 和 Logcat 的所有相关条目。

调试或性能分析时出现 adb 异常

使用 Platform Tools 29.0.3 时,原生调试和 Android Studio 性能剖析器可能无法正常工作,并且如果您依次选择 Help > Show Log,可能会在 idea.log 文件中看到“AdbCommandRejectedException”或“Failed to connect port”。将 Platform Tools 升级到 29.0.4 或更高版本可以解决这两个问题。

如需升级 Platform Tools,请执行以下操作:

  1. 依次点击 Tools > SDK Manager 或点击工具栏中的 SDK Manager 图标 ,从 Android Studio 打开 SDK 管理器。
  2. 点击 Android SDK Platform-Tools 旁边的复选框,使其显示复选标记。左侧列中应会显示下载图标
  3. 点击 ApplyOK

插件阻止“Build Output”窗口正常运行

使用 CMake simple highlighter 插件会阻止内容显示在“Build Output”窗口中。build 会运行,“Build Output”标签页会显示,但系统不会输出任何内容(问题 204791544)。

安装顺序阻止启动

如果先安装新版本的 Android Studio,再安装旧版本的 Android Studio,可能会导致旧版本无法启动。例如,如果您先安装 Canary 版 Android Studio,然后尝试安装并启动稳定版本,则稳定版本可能无法启动。在此类情况下,您必须清除缓存,才能启动稳定版本(旧版本)。在 macOS 上,如需清除缓存,请删除 Library/ApplicationSupport/Google/AndroidStudioversion_number 目录。在 Windows 上,如需清除缓存,请使用磁盘清理功能。

Android Gradle 插件的已知问题

本部分将介绍最新的稳定版 Android Gradle 插件中存在的已知问题。

系统不会对所有动态功能库依赖项进行 lint 检查

在设置了 checkDependencies = true 的情况下从应用模块运行 lint 时,系统不会检查动态功能库依赖项,除非这些库依赖项同时也是应用依赖项(问题 191977888)。解决方法之一是,您可以在这些库上运行 lint 任务。

对使用回车符命名的文件签名

JAR 签名(v1 方案)不支持包含回车符的文件名(问题 #63885809)。

AGP 7.2.x 未正式支持 API 级别 33

AGP 7.2.x 未正式支持 API 级别 33,如果以该 API 级别为目标平台,AGP 7.2.x 会显示警告。如需抑制此警告,您可以将以下代码添加到 gradle.properties 文件,以便明确允许使用未经测试的 SDK:

android.suppressUnsupportedCompileSdk=33

Android Studio Dolphin 附带的 AGP 7.3.x 支持 API 级别 33,因此您应在其成为稳定版本后升级到此级别。

API 变更

在 Android Gradle 插件 3.0.0 及更高版本引入的 API 变更中,部分功能被移除,因此您的现有 build 可能会出现异常。插件的更高版本可能会引入新的公共 API 来替代失效的旧功能。

在构建时可能无法正常修改变体输出

新插件不支持使用 Variant API 来操纵变体输出,但仍然支持使用该 API 处理某些简单任务,例如在构建时更改 APK 名称,具体如下所示:

// If you use each() to iterate through the variant objects,
// you need to start using all(). That's because each() iterates
// through only the objects that already exist during configuration time—
// but those object don't exist at configuration time with the new model.
// However, all() adapts to the new model by picking up object as they are
// added during execution.
android.applicationVariants.all { variant ->
    variant.outputs.all {
        outputFileName = "${variant.name}-${variant.versionName}.apk"
    }
}

不过,涉及访问 outputFile 对象的复杂任务已不再受支持。这是因为在配置阶段不会再创建专门针对特定变体的任务。这会导致插件不能预先了解所有的输出,但这也意味着将会缩短配置时间。

manifestOutputFile 不再可用

processManifest.manifestOutputFile() 方法不再可用,您在调用该方法时将会遇到以下错误:

A problem occurred configuring project ':myapp'.
   Could not get unknown property 'manifestOutputFile' for task
   ':myapp:processDebugManifest' of type
   com.android.build.gradle.tasks.ProcessManifest.

您可以调用 processManifest.manifestOutputDirectory() 来获取包含所有已生成清单的目录路径,而无需调用 manifestOutputFile() 来获取每个变体的清单文件。然后您可以找到相应清单,并对该清单应用您的逻辑。以下示例将在清单中动态更改版本代码:

android.applicationVariants.all { variant ->
    variant.outputs.all { output ->
        output.processManifest.doLast {
            // Stores the path to the maifest.
            String manifestPath = "$manifestOutputDirectory/AndroidManifest.xml"
            // Stores the contents of the manifest.
            def manifestContent = file(manifestPath).getText()
            // Changes the version code in the stored text.
            manifestContent = manifestContent.replace('android:versionCode="1"',
                    String.format('android:versionCode="%s"', generatedCode))
            // Overwrites the manifest with the new text.
            file(manifestPath).write(manifestContent)
        }
    }
}

已修复的已知问题

本部分介绍最新版本中已经修复的已知问题。如果您遇到所述的任何问题,请将 Android Studio 更新为最新稳定版或预览版

Android Studio 2021.1.1 中已修复的问题

  • 缺少 lint 输出:lint 任务的状态为 UP-TO-DATE 状态时无输出到 stdout 的 lint 文本输出(问题 191897708)。已在 AGP 7.1.0-alpha05 中修复。
  • 对使用 Hilt 插件的应用项目进行单元测试时出现问题:单元测试类路径包含非插桩应用类,这意味着,运行单元测试时,Hilt 不会插桩应用类来处理依赖项注入(问题 213534628)。已在 AGP 7.1.1 中修复。

Android Studio 2020.3.1 中已修复的问题

  • Kotlin 项目中的 lint 异常:设置了 checkDependencies = true 的 Kotlin 项目可能会遇到 null 指针异常或错误(问题 #158777858)。

Android Studio 4.2 中已修复的问题

  • IDE 在 macOS Big Sur 上卡死:Android Studio 4.1 可能会在您打开对话框时卡死。

Android Studio 4.1 中修复的问题

  • 重启以应用之前 IDE 版本中的内存设置:更新 Android Studio 后,您需要重启 Android Studio 才能应用从之前 IDE 版本中迁移过来的任何内存设置。
  • 默认情况下,不再生成具有自定义权限字符串的清单类:如果您要生成该类,请设置 android.generateManifestClass = true

Android Studio 3.6 中已修复的问题

  • LineageOS 上的 APK 安装错误:将应用部署到运行某些版本的 LineageOS 或 CyanogenMod 的设备可能会失败,并抛出 INSTALL_PARSE_FAILED_NOT_APK 异常。

    在 Android Studio 3.6 Beta 1 及更高版本上,当您将应用部署到 LineageOS 或 CyanogenMod 设备时,IDE 会通过执行完整的应用安装来处理此异常,这可能会导致部署时间变长。

Android Studio 3.5.2 中已修复的问题

  • XML 代码样式损坏:在修改 XML 代码时,如果从菜单栏中依次选择 Code > Reformat Code,IDE 会应用不正确的代码样式。

Android Studio 3.3.1 中已修复的问题

  • 扫描基于 C++ 的项目时出现内存不足错误:如果 Gradle 扫描的项目在同一驱动器上的多个位置都有 C++ 代码,则扫描会涵盖这些位置的首个共通目录下的所有目录。扫描大量目录和文件可能会导致出现内存不足错误。

    如需详细了解此问题,请参阅与该问题相关的错误