Android Studio 预览版中的新功能

Android Studio 3.5 已发布稳定版。您可以在此处下载

Android Studio 4.0 目前已发布 Canary 版和开发者版,Android Studio 3.6 目前已发布 Beta 版。

如需了解与各版本有关的最新资讯,包括每个版本中的重要修复的列表,另请参阅版本更新

如果您在使用 Android Studio 预览版时遇到任何问题,请告知我们。您的错误报告有助于我们改进 Android Studio。

Android Studio 4.0

本部分简要介绍了 Android Studio 4.0 中的新功能和变更。

CPU Profiler 界面升级

系统轨迹界面升级

根据您的反馈,CPU Profiler 界面经过了全新改版,以提供更直观的工作流。显著变更包括:

  • CPU 记录现在已从主分析器时间轴分离出来,使分析更加容易。记录的数据按组显示在 Profiler 窗口的左侧。您可以通过点击窗口右上角的 分析器中的选项图标 选项图标或通过拖放组中的各项来上下移动组以重新整理列表。
  • 为使并排分析更容易,您现在可以查看线程活动时间轴中的所有线程活动(包括方法、函数和事件)。
  • 现在,Flame ChartTop DownBottom Up 分析对应的标签页位于右侧列中。在“Threads”组中,对于系统轨迹记录,线程会自动展开;对于其他记录类型,线程会默认收起。双击线程名称可将其展开或收起。
  • 系统轨迹界面(如上面的屏幕截图中所示)也得到了改进。例如,为了让您更容易区分,系统现在使用独特的颜色显示不同的事件。

此功能仍在开发中,因此请继续提供反馈

移除了“分离注释处理”功能

已移除将注释处理进程分离到一项专门任务中的功能。此选项过去用于在纯 Java 项目中使用非增量注释处理器时维持增量 Java 编译;过去的启用方法是在 gradle.properties 文件中将 android.enableSeparateAnnotationProcessing 设为 true,但这种方法不再起作用。

您应改为使用增量注释处理器来提升构建性能。

“Build Speed”窗口

将 Android Studio 4.0 Canary 3 与 Android Gradle 插件 4.0.0-alpha03 及更高版本一起使用时,Build Speed 窗口可帮助您了解和诊断与构建流程有关的问题,如优化被停用和任务配置不当问题。将 Android Studio 4.0 Canary 3 及更高版本与 Android Gradle 插件 4.0.0-alpha03 及更高版本一起使用时,您可以按如下方式打开 Build Speed 窗口:

  1. 通过从菜单栏中依次选择 Build > Make Project 来构建您的应用(如果您尚未这样做)。
  2. 从菜单栏中依次选择 View > Tool Windows > Build
  3. Build 窗口中,通过以下某种方式打开 Build Speed 窗口:
    • Android Studio 构建完您的项目后,点击 Build Speed 标签页。
    • Android Studio 构建完您的项目后,点击 Build Output 窗口右侧的链接。

Build Speed 窗口将可能的构建问题组织在左侧的树中。您可以检查并点击每个问题,以在右侧的面板中调查其详细信息。当 Android Studio 分析您的构建时,它会计算决定构建时长的一组任务,并提供直观的图表来帮助您了解其中每项任务所产生的影响。您也可以展开 Warnings 节点来获取有关警告的详细信息。

构建速度图表

哪些任务决定构建时长?

Gradle 按任务的相互依赖性、项目结构和 CPU 负载来决定任务的执行,并按顺序或并行执行任务。对于给定的构建,Build Speed 窗口会突出显示决定当前构建时长的一组按顺序执行的任务。要缩短总体构建时间,最好首先解决这些突出显示的任务执行效率低下的问题。

请注意,对于您执行的每次构建,您可能会看到一组不同的任务决定了构建时长。例如,如果您对构建配置进行更改、通过一组不同的任务运行构建(如增量构建)或在不同的约束条件(如较重的 CPU 负载)下运行构建,则“Build Speed”窗口可能会突出显示对该构建的时长影响最大的一组不同的任务。由于这种变化,您可能希望在多次构建之间使用“Build Speed”窗口来不断缩短构建时长。

Multi Preview

Multi Preview 是一款可视化工具,用于同时预览不同设备中及采用不同配置的布局,这样可帮助找出布局中的潜在问题。

您可以通过点击 IDE 窗口右上角的 Multi Preview 标签页来使用该功能:

“Multi Preview”按钮

有两个不同的配置集可供您选择,即“Pixel Devices”和“Project Locales”。要在这些配置集之间切换,请从“Multi Preview”窗口顶部的下拉列表中选择:

Multi Preview 演示

实时布局检查器

您可以使用更新后的实时布局检查器来调试布局,该工具可以在将应用部署到设备时提供应用界面的完整实时数据分析。

要打开一个布局检查器窗口,请依次转到 View > Tools Windows > Layout Inspector。除了与现有布局检查器相同的许多功能之外,实时布局检查器还包含如下功能:

  • 动态布局层次结构:随着设备上的视图发生变化而进行更新。

动态布局层次结构

  • 属性值解析堆栈:调查资源属性值在源代码中的来源位置,点击属性窗格中的超链接即可转到其位置。

属性值解析堆栈

  • 3D 视图:使用高级 3D 可视化功能,在运行时查看应用的视图层次结构。要使用此功能,只需在实时布局检查器窗口中点击相应的布局并进行旋转。

布局检查器:3D 视图

只有在将您的应用部署到搭载 API 级别 29 或更高级别的设备上时,才能使用实时布局检查器。您还必须启用该功能,方法是依次转到 File > Settings > Experimental 并勾选 Enable Live Layout Inspector 旁边的框。

支持 Jetpack Compose

Jetpack Compose 工具包提供了一种用于构建应用界面的现代方法。此外,该工具包还融合了 Kotlin 的所有优势,如帮助您编写可完全与 Java 互操作的简洁而惯用的代码。

为了获得最佳 Jetpack Compose 开发体验,您应使用最新版本的 Android Studio 4.0。这是因为,当您搭配使用 Android Studio 和 Jetpack Compose 来开发应用时,可以从智能编辑器功能中受益,这些功能包括“新建项目”模板和立即预览 Compose 界面等。

要了解详情并开始使用,请转到 Jetpack Compose 概览

D8 和 R8 中的 Java 8 库脱糖

Android Studio 现在支持使用多种 Java 8 语言 API,而无需为应用设置最低 API 级别。

通过一个称为“脱糖”的过程,Android Studio 3.0 及更高版本中的 DEX 编译器 D8 已经为 Java 8 语言功能(如 lambda 表达式、默认接口方法、try-with-resources 等等)提供了大量的支持。在 Android Studio 4.0 中,脱糖引擎经过扩展,能够使 Java 语言 API 脱糖。这意味着,您现在可以在支持旧版 Android 的应用中添加过去仅在最新 Android 版本中可用的标准语言 API(如 java.util.streams)。

此版本支持下面一组 API:

  • 顺序流 (java.util.stream)
  • java.time 的子集
  • java.util.function
  • java.util.{Map,Collection,Comparator} 的最近新增内容
  • 可选内容(java.util.Optional, java.util.OptionalIntjava.util.OptionalDouble)以及对上述 API 很有用的一些其他新类
  • java.util.concurrent.atomic 的一些新增内容(AtomicIntegerAtomicLongAtomicReference 的新方法)
  • ConcurrentHashMap(包含 Android 5.0 的问题修复)

为了支持这些语言 API,D8 编译了一个单独的库 DEX 文件,其中包含缺失 API 的实现,并将其添加到您的应用中。脱糖过程会重新编写应用的代码,以便在运行时改用此库。

要启用对这些语言 API 的支持,请在模块的 build.gradle 文件中添加以下内容:

android {
      defaultConfig {
        // Required when setting minSdkVersion to 20 or lower
        multiDexEnabled true
      }

      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:1.0.4'
    }
    

如果您遇到问题或希望支持其他 API,请告知我们,只需在我们的错误跟踪器中提交错误即可。

支持 Kotlin DSL 脚本文件

Android Gradle 插件现在支持 Kotlin DSL 构建脚本文件 (*.kts)。与 Android Studio 一起使用时,某些 IDE 功能(如“Project Structure”对话框和构建脚本快速修复)现在也支持读取和写入 Kotlin 构建脚本文件。

适用于 ProGuard 规则的智能编辑器功能

Android Studio 现在可以在您打开 ProGuard 规则文件时提供智能编辑器功能,如语法突出显示、代码补全和错误检查。该编辑器还与 Android Studio 项目集成,以便为所有类、方法和字段提供完整的符号补全,并且包括快速导航和重构功能。

修改 ProGuard 规则文件时使用的智能编辑器功能

新的 Motion Editor

Android Studio 现在包含一个适用于 MotionLayout 布局类型的视觉设计编辑器,可让您更轻松地创建和预览动画。

Motion Editor 提供了一个简单的界面来操控 MotionLayout 库中的元素,该库是 Android 应用中动画的基础。在之前的版本中,创建和更改这些元素需要手动修改 XML 资源文件中的约束。现在,Motion Editor 支持开始状态和结束状态、关键帧、转换和时间轴,可以为您生成此 XML 文件。

要开始使用 Motion Editor,请执行以下操作:

  1. 创建一个 ConstraintLayout
  2. 右键点击 Layout Editor 中的预览区域。
  3. 点击 Convert to MotionLayout,如下所示。

Android Studio 将 ConstraintLayout 转换为 MotionLayout 后,也会将一个 Motion Scene 文件添加到包含您的 XML 文件的目录中。

MotionLayout 随后成为您的根布局,并且它会出现在 Motion Editor 界面中。布局已包含开始 ConstraintSet、结束 ConstraintSet 以及从开始到结束的转换。

您可以使用概览图来选择 ConstraintSetTransition 并在选择面板中选择组件。

然后,您可以修改开始或结束 ConstraintSet 的约束和属性,修改方式与修改 ConstraintLayout 一样。

如果您要在图中构建更多元素,可以使用创建图标来快速添加 ConstraintSetTransitionOnClick/OnSwipe 手势。

要添加关键帧,请先点击 Transition 箭头:

然后,在 Transition 时间轴窗格中,点击右上角并选择 KeyPosition

此操作会打开一个对话框,您可以从中设置关键帧的属性。

您还可以在属性面板中向转换添加 OnClickOnSwipe 处理程序。

此操作会打开一个对话框,您可以从中设置点击操作的属性,如目标组件和拖动方向。

Motion Editor 支持在设计图面上预览动画。选择动画后,点击时间轴上方的 Play 图标 即可预览动画。

Android Gradle 插件 4.0.0 中的新功能

本部分介绍了 Android Gradle 插件 4.0.0 中包含的新功能和行为变化。

用于启用或停用构建功能的新选项

Android Gradle 插件 4.0.0-alpha05 引入了一种新方法来控制您要启用和停用的构建功能,如视图绑定、数据绑定和 Jetpack Compose。添加新功能后,默认情况下,这些功能处于停用状态。您随后可以使用 buildFeatures 块来仅启用所需的功能,它可以帮助您优化项目的构建性能。您可以在模块级 build.gradle 文件中为每个模块设置相应的选项,如下所示:

    android {
        // The default value for each feature is shown below. You can change the value to
        // override the default behavior.
        buildFeatures {
            // Determines whether to enable support for Jetpack Compose.
            compose = false
            // Determines whether to generate a BuildConfig class.
            buildConfig = true
            // Determines whether to support View Binding.
            // Note that the viewBinding.enabled property is now deprecated.
            viewBinding = false
            // Determines whether to support Data Binding.
            // Note that the dataBinding.enabled property is now deprecated.
            dataBinding = false
            // Determines whether to generate binder classes for your AIDL files.
            aidl = true
            // Determines whether to support RenderScript.
            renderScript = true
            // Determines whether to support injecting custom variables into the module’s R class.
            resValues = true
            // Determines whether to support shader AOT compilation.
            shaders = true
        }
    }
    

您还可以为项目中的所有模块指定这些功能的默认设置,方法是在项目的 gradle.properties 文件中添加下面的一项或多项,如下所示。请注意,您仍然可以使用模块级 build.gradle 文件中的 buildFeatures 块来替换这些项目范围的默认设置。

android.defaults.buildfeatures.buildconfig=true
    android.defaults.buildfeatures.aidl=true
    android.defaults.buildfeatures.renderscript=true
    android.defaults.buildfeatures.resvalues=true
    android.defaults.buildfeatures.shaders=true
    

功能对功能的依赖性

在以前的 Android Gradle 插件版本中,所有动态功能模块都只能依赖于应用的基础模块。使用 Android Gradle 插件 4.0.0 时,您现在可以添加依赖于其他功能模块的功能模块。也就是说,:video 功能可以依赖于 :camera 功能,后者依赖于基础模块,如下图所示。

功能对功能的依赖性

:video 动态功能依赖于 :camera 功能,后者依赖于 :app 基础模块。

这意味着,当您的应用请求下载某个动态功能模块时,它也会下载该模块所依赖的其他功能模块。为您的应用创建动态功能模块后,您可以在模块的 build.gradle 文件中声明功能对功能的依赖性。例如,:video 模块声明对 :camera 的依赖性,如下所示:

// In the build.gradle file of the ':video' module.
    dependencies {
        // All dynamic feature modules must declare a dependency
        // on the base module.
        implementation project(':app')
        // Declares that this module also depends on the 'camera'
        // dynamic feature module.
        implementation project(':camera')
        ...
    }
    

此外,您还应在 Android Studio 中启用功能对功能的依赖性功能(例如,为了在修改运行配置时支持该功能),方法是从菜单栏中依次点击 Help > Edit Custom VM Options,并添加以下内容:

-Drundebug.feature.on.feature=true
    

移除了“feature”和“instantapp”Android Gradle 插件

Android Gradle 插件 3.6.0 弃用了功能插件 (com.android.feature) 和免安装应用插件 (com.android.instantapp),改为使用动态功能插件 (com.android.dynamic-feature),以通过 Android App Bundle 构建和打包免安装应用。

在 Android Gradle 插件 4.0.0-alpha01 及更高版本中,完全移除了这些已弃用的插件。因此,要使用最新的 Android Gradle 插件,您需要迁移免安装应用以支持 Android App Bundle。通过迁移免安装应用,您可以利用 app bundle 的优势,并简化应用的模块化设计

Kotlin Android 实时模板

Android Studio 现在包含适用于 Kotlin 类的 Android 实时模板。例如,您现在可以输入 toast 并按 Tab 键来快速插入一个消息框。如需查看可用实时模板的完整列表,请从菜单栏中依次点击 File > Settings(或在 macOS 上,依次点击 Android Studio > Preferences),然后依次转到 Editor > Live Templates

Fragment 向导和新的 Fragment 模板

现在,当您依次转到 File > New > Fragment > Gallery 或在 Navigation Editor 中点击 Create new destination 时,会出现新的 Android Fragment 向导和新的 Fragment 模板。

Fragment 库向导。

Fragment 库向导。

4.0 预览版的已知问题

本部分介绍了 Android Studio 4.0 预览版的当前已知问题。

缺少“Run”、“Debug”和“Profile”工具栏按钮

如果您对操作按钮的 Run/Debug 组进行了自定义(例如,通过在 SettingsPreferences 窗口中的 Appearance & Behavior > Menus and Toolbars 下修改选项),那么在您重启 IDE 后,这些操作按钮可能会从工具栏中消失。这是 Android Studio 4.0 所基于的 IntelliJ 版本的已知问题(请参阅问题 IDEA-228450)。

要解决此问题,请还原您对这些按钮所做的任何自定义,具体操作步骤如下:

  1. 依次选择 File > Settings(或在 macOS 上,依次选择 Android Studio > Preferences)。
  2. 在窗口左侧,依次转到 Appearance & Behavior > Menus and Toolbars
  3. 在窗口右侧,依次转到 Main Toolbar > Toolbar Run Actions,然后选择 Run/Debug
  4. 在窗口顶部附近,点击 Revert 图标 ,然后选择 Restore Run/Debug
  5. 点击 OK。您现在应该会在工具栏中看到缺少的按钮。

Canary 5 没有可用的补丁程序

Android Studio 4.0 Canary 5 没有可用于之前发布的 Android Studio 4.0 Canary 版本的补丁程序。要安装 Android Studio 4.0 Canary 5,请从 Android Studio 下载页面进行下载。

Canary 5 中的分析器和实时布局检查器

从 Android Studio 4.0 Canary 5 开始,实时布局检查器和分析器无法在 Windows 上正常运行,从而导致出现以下错误消息:

    transfer error: couldn't create file: Read-only file system.
    

要解决此问题,请升级到 Android Studio 4.0 Canary 7 或更高版本。

缺少 Kotlin Maven 代码库

如果您使用的是 Android Studio 4.0 Canary 4 或更低版本,则可能会看到以下错误消息:

Application build has failed with an error (Could not find org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.3.60-eap-25)
    

要解决此问题,请更新到 Android Studio 4.0 Canary 5 或更高版本。

Android Studio 3.6

本部分简要介绍了 Android Studio 3.6 中的新功能和变化。

用于优化 Gradle 同步时间的新选项

在之前的版本中,Android Studio 会在 Gradle Sync 执行期间检索所有 Gradle 任务的列表。对于大型项目来说,检索任务列表可能会导致同步时间较长。

要提高 Gradle Sync 性能,请依次转到 File > Settings > Experimental,然后选择 Do not build Gradle task list during Gradle sync

启用此选项后,Android Studio 会在同步期间跳过构建任务列表,这样可使 Gradle Sync 更快地完成并提高界面响应能力。请注意,当 IDE 跳过构建任务列表时,Gradle 面板中的任务列表为空,并且构建文件中的任务名称自动补全功能不起作用。

将纯 Kotlin APK 源代码附加到分析器

现在,当您分析和调试预构建的 APK 时,可以附加纯 Kotlin 外部 APK 源代码。

请按照附加 Java 文件 (.java) 的用户指南中的说明进行操作,但应选择您的 Kotlin 源文件 (.kt)。

设计编辑器中的拆分视图

设计编辑器(如 Layout Editor 和 Navigation Editor)现在提供了 Split 视图,可让您同时查看界面的 Design 视图和 Code 视图。要启用拆分视图,请点击编辑器窗口右上角的 Split 图标 拆分视图图标

拆分视图同时显示设计视图和文本视图

Memory Profiler 中的泄漏检测

在 Memory Profiler 中分析堆转储时,您现在可以过滤 Android Studio 认为可能表明应用中的 ActivityFragment 实例存在内存泄漏的分析数据。

过滤器显示的数据类型包括:

  • 已销毁但仍被引用的 Activity 实例。
  • 没有有效的 FragmentManager 但仍被引用的 Fragment 实例。

在某些情况(如以下情况)下,过滤器可能会产生误报:

  • 已创建 Fragment,但尚未使用它。
  • 正在缓存 Fragment,但它不是 FragmentTransaction 的一部分。

要使用此功能,请先捕获堆转储将堆转储文件导入 Android Studio。要显示可能泄漏内存的 Fragment 和 Activity,请选中 Memory Profiler 的堆转储窗格中的 Activity/Fragment Leaks 复选框。

Memory Profiler:内存泄漏检测

过滤堆转储以检测内存泄漏。

应用更改

您现在可以添加一个类,然后将该代码更改部署到正在运行的应用,方法是点击 Apply Code Changes 图标 Apply Code Changes 图标Apply Changes and Restart Activity 图标 Apply Changes 图标

要详细了解这两项操作之间的区别,请参阅应用更改

导入经过更新的 APK

当项目中的 APK 在 IDE 之外进行了更新时,您不再需要创建新项目。Android Studio 会检测 APK 中的更改,并为您提供用于重新导入 APK 的选项。

NDK 更新

以下更新支持 Android Studio 中的原生 (C/C++) 开发。

Kotlin 支持

Android Studio 中的以下 NDK 功能以前在 Java 中受支持,现在也在 Kotlin 中受支持:

  • 从 JNI 声明转到 C/C++ 中的对应实现函数。只需将鼠标悬停在托管源代码文件中的行号附近的 C 或 C++ 项标记上方,即可查看此映射。
  • 自动为 JNI 声明创建存根实现函数。首先定义 JNI 声明,然后输入“jni”或 C/C++ 文件中的方法名称进行激活。

  • 未使用的原生实现函数会在源代码中突出显示为警告。缺少实现的 JNI 声明也会突出显示为错误。

  • 如果您重命名(重构)某个原生实现函数,则所有对应的 JNI 声明都会更新。重命名 JNI 声明可更新原生实现函数。

  • 对隐式绑定的 JNI 实现进行签名检查。

其他关于 JNI 的改进

  • 外观显示

    • JNI 实现函数中会显示参数和返回值的类型提示。
    • 经过 JNI 重整的函数名称可以折叠。

  • RegisterNatives 支持

    • 自动补全方法声明名称、参数类型和返回类型。

    • 对方法声明名称进行重命名重构。

    • 对绑定 JNI 函数进行签名检查。

  • 有关 JNI 函数的其他帮助

    • 对于以下函数中的字符串字面量的自动补全、检查、导航和重命名重构支持:
      • FindClass
      • GetMethodIDGetStaticMethodID
      • GetFieldIDGetStaticFieldID
    • 针对以下函数的各种检查:
      • Call[Static]<type>Method
      • CallNonvirtual<type>Method
      • Get[Static]<type>Field
      • NewObject

Android Gradle 插件的更新

当您使用最新预览版的 Android Gradle 插件时,可获得以下更新。

支持 Maven Publish 插件

Android Gradle 插件 3.6-alpha07 及更高版本支持 Maven Publish Gradle 插件,可让您将构建工件发布到 Apache Maven 代码库。Android Gradle 插件会为应用或库模块中的每个构建变体工件创建一个组件,您可以使用它来自定义要发布到 Maven 代码库的发布内容

Android 插件所创建的组件取决于模块是否使用应用或库插件,如下表所述。

Android Gradle 插件 发布内容工件 组件名称
com.android.library AAR components.variant
com.android.application APK 和可用的 ProGuard 或 R8 映射文件的 ZIP components.variant_apk
com.android.application Android App Bundle (AAB) components.variant_aab

以下代码示例为 AAR 库的发布和调试构建变体创建了发布内容。每项发布内容都会应用匹配的组件,并自定义所生成 POM 的属性,如 Maven 坐标。

// Because the components are created only during the afterEvaluate phase, you must
    // configure your publications using the afterEvaluate() lifecycle method.
    afterEvaluate {
        publishing {
            publications {
                // Creates a Maven publication called "release".
                release(MavenPublication) {
                    // Applies the component for the release build variant.
                    from components.release

                    // You can then customize attributes of the publication as shown below.
                    groupId = 'com.example.MyLibrary'
                    artifactId = 'final'
                    version = '1.0'
                }
                // Creates a Maven publication called “debug”.
                debug(MavenPublication) {
                    // Applies the component for the debug build variant.
                    from components.debug

                    groupId = 'com.example.MyLibrary'
                    artifactId = 'final-debug'
                    version = '1.0'
                }
            }
        }
    

要创建发布内容来以 APK 的 ZIP 文件或 Android App Bundle (AAB) 的形式发布您的应用,只需使用适当的组件即可,如下所示。

afterEvaluate {
        publishing {
            publications {
                paidRelease(MavenPublication) {
                  // The following applies a component to this publication
                  // which results in publishing an app bundle.
                  from components.paidRelease_aab

                  groupId = 'com.example.MyApp'
                  artifactId = 'paid-release-aab'
                  version = '1.0'
                }
                paidDebug(MavenPublication) {
                  // The following applies a component to this publication
                  // which results in publishing APKs in a ZIP file.
                  from components.paidDebug_apk

                  groupId = 'com.example.MyApp'
                  artifactId = 'paid-debug-apks'
                  version = '1.0'
                }
            }
        }
    

在您创建发布内容后,Maven Publish 插件会创建发布任务,您可以通过这些任务将工件发布到您指定的代码库

新的默认打包工具

使用 Android Gradle 插件 3.6.0-alpha09 或更高版本来构建应用的调试版本时,该插件会使用一个新的打包工具(称为“zipflinger”)来构建 APK。这一新工具应该能够提高构建速度。不过,如果您遇到问题,请报告错误。您也可以通过在 gradle.properties 文件中添加以下内容来恢复使用旧的打包工具:

android.useNewApkCreator=false
    

重构菜单选项以启用免安装应用支持

现在,您可以在创建应用项目后随时使基础模块支持免安装体验,具体操作步骤如下:

  1. 从菜单栏中依次选择 View > Tool Windows > Project,打开 Project 面板。
  2. 右键点击基础模块(通常名为“app”),然后依次选择 Refactor > Enable Instant Apps Support
  3. 在出现的对话框中,从下拉菜单中选择基础模块。
  4. 点击 OK

要了解详情,请阅读 Google Play 免安装体验概览

在 APK 分析器中对类和方法字节码进行去混淆处理

检查 DEX 文件时,APK 分析器现在支持对类和方法字节码进行去混淆处理。要对字节码进行去混淆处理,请按以下步骤操作:

  1. 从菜单栏中依次选择 Build > Analyze APK
  2. 在出现的对话框中,转到您要检查的 APK 并选择该 APK。
  3. 点击 Open
  4. 在 APK 分析器中,选择您要检查的 DEX 文件。
  5. 在 DEX 文件查看器中,为您要分析的 APK 加载 ProGuard 映射文件
  6. 右键点击您要检查的类或方法,然后选择 Show bytecode

视图绑定

在代码中引用视图时,视图绑定可确保编译时安全性。您现在可以将 findViewById() 替换为自动生成的绑定类引用。

要开始使用视图绑定,请在每个模块的 build.gradle 文件中添加以下内容:

android {
        viewBinding.enabled = true
    }
    

要了解详情,请阅读视图绑定文档。如果您有任何反馈或遇到任何问题,请报告错误

可恢复的 SDK 下载

使用 SDK 管理器下载 SDK 组件和工具时,Android Studio 现在允许您恢复已中断的下载(例如,由于网络问题),而不是从头开始重新下载。当互联网连接不可靠时,此增强功能对大量数据的下载(如 Android 模拟器或系统映像)特别有用。

此外,如果您在后台运行 SDK 下载任务,现在可以使用状态栏中的控件暂停或恢复下载。

状态栏中的后台下载任务,带有可让您暂停或恢复下载的新控件。

状态栏中的后台下载任务,带有可让您暂停或恢复下载的新控件。

IntelliJ IDEA 2019.2

核心 Android Studio IDE 已更新,纳入了 IntelliJ IDEA(直到 2019.2 版本)中的相关改进,如“Services”工具窗口。

要详细了解 2019.2 版本累积包含其他 IntelliJ 版本中的哪些改进,请参阅以下页面:

用于切换 Gradle 离线模式的新位置

要启用或停用 Gradle 离线模式,请先从菜单栏中依次选择 View > Tool Windows > Gradle。然后,在 Gradle 窗口顶部附近,点击 Toggle Offline Mode 图标 Gradle 面板中的 Gradle 离线按钮。

3.6 预览版的已知问题

本部分介绍了 Android Studio 3.6 预览版的当前已知问题。

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

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

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