配置 Android Studio

Android Studio 提供诸多向导和模板,可用于验证 Java 开发套件 (JDK) 和可用 RAM 等系统要求,以及配置默认设置,例如经过优化的默认 Android 虚拟设备 (AVD) 模拟和更新的系统映像。本文档介绍了可用于自定义 Android Studio 使用方式的其他配置设置。

您可以通过 Android Studio 的 Help 菜单访问下面这两个配置文件:

  • studio.vmoptions:自定义 Android Studio 的 Java 虚拟机 (JVM) 选项,例如堆大小和缓存大小。请注意,在 Linux 计算机上,此文件可能会命名为 studio64.vmoptions,具体取决于您使用的 Android Studio 版本。
  • idea.properties:自定义 Android Studio 的属性,例如插件文件夹路径或支持的文件大小上限。

如需模拟器和设备的设置及使用方式的相关文档,请参阅以下主题:

查找配置文件

两个配置文件都存储在 Android Studio 的配置文件夹中。文件夹名称取决于您使用的 Android Studio 版本。

对于 Android Studio 4.1 及更高版本,配置文件位于以下位置:

  • Windows

    语法:%APPDATA%\Google\<product><version>

    示例:C:\Users\YourUserName\AppData\Roaming\Google\AndroidStudio4.1

  • macOS

    语法:~/Library/Application Support/Google/<product><version>

    示例:~/Library/Application Support/Google/AndroidStudio4.1

  • Linux

    语法:~/.config/Google/<product><version>

    示例:~/.config/Google/AndroidStudio4.1

对于 Android Studio 4.0 及更低版本,配置文件位于以下位置:

  • Windows:%USERPROFILE%\.CONFIGURATION_FOLDER
  • macOS:~/Library/Preferences/CONFIGURATION_FOLDER
  • Linux:~/.CONFIGURATION_FOLDER

您也可以使用以下环境变量指向其他位置的特定替换文件:

  • STUDIO_VM_OPTIONS:设置 .vmoptions 文件的名称和位置。
  • STUDIO_PROPERTIES:设置 .properties 文件的名称和位置。

您可以访问 Android build 中的 Java 版本,配置要使用的 JDK。

自定义虚拟机选项

借助 studio.vmoptions 文件,您可以自定义 Android Studio 的 JVM 选项。为了提高 Android Studio 的性能,最常用的调节选项是堆大小上限,但您也可以使用 studio.vmoptions 文件替换其他默认设置,例如初始堆大小、缓存大小和 Java 垃圾回收开关。

如需创建新的 studio.vmoptions 文件或打开现有文件,请执行以下操作:

  1. 依次点击 Help > Edit Custom VM Options。如果您之前从未修改过 Android Studio 的虚拟机选项,Android Studio 将提示您新建一个 studio.vmoptions 文件。点击 Create 以创建文件。
  2. studio.vmoptions 文件会在 Android Studio 的编辑器窗口中打开。修改该文件以添加您自己的自定义虚拟机选项。如需可自定义 JVM 选项的完整列表,请参阅 Oracle 的 Java HotSpot 虚拟机选项页面。

您创建的 studio.vmoptions 文件将添加到默认的 studio.vmoptions 文件中,后者位于 Android Studio 安装文件夹内的 bin/ 目录中。

请勿直接修改 Android Studio 程序文件夹内的 studio.vmoptions 文件。尽管您可以访问该文件以查看 Android Studio 的默认虚拟机选项,但仅修改自己的 studio.vmoptions 文件可确保您不会替换 Android Studio 的重要默认设置。因此,在您的 studio.vmoptions 文件中,请仅替换您关注的属性,以便 Android Studio 继续为您未更改的所有属性使用默认值。

堆大小上限

默认情况下,Android Studio 的最大堆大小为 1280MB。如果您处理的是大项目,或者您的系统有大量 RAM 可用,您可以通过增大 Android Studio 进程(例如核心 IDE、Gradle 守护程序和 Kotlin 守护程序)的最大堆大小以提升性能。

Android Studio 会自动检查可采取的堆大小优化措施,并在检测到性能可以提升时通知您。

内存设置,可让您为 Android Studio 进程配置最大 RAM 容量。

图 1. 有关推荐内存设置的通知。

如果您使用的是 64 位系统并配有不少于 5 GB 的 RAM,您还可以手动调整项目的堆大小。若要提交上述请求,请执行以下操作:

  1. 在菜单栏中依次点击 File > Settings(或在 macOS 上,依次点击 Android Studio > Preferences)。
  2. 依次点击 Appearance & Behavior > System Settings > Memory Settings

    内存设置,可让您为 Android Studio 进程配置最大 RAM 容量。

    图 2. 在内存设置中配置最大 RAM 容量。

  3. 调整堆大小。

  4. 点击 Apply

    如果您更改了 IDE 的堆大小,则必须重启 Android Studio 才能让新的内存设置生效。

导出和导入 IDE 设置

您可以导出一个 Settings.jar 文件,其中包含项目的全部或部分首选 IDE 设置。然后,您可以将该 JAR 文件导入其他项目,并/或将该 JAR 文件共享给同事,以便他们将其导入到自己的项目中。

如需了解详情,请参阅 IntelliJ IDEA 中的分享 IDE 设置

自定义 IDE 属性

通过 idea.properties 文件,您可以自定义 Android Studio 的 IDE 属性,例如用户所安装插件的路径,以及 IDE 支持的文件大小上限。idea.properties 文件会与 IDE 的默认属性合并,以便您仅指定需替换的属性。

如需创建新的 idea.properties 文件或打开现有文件,请执行以下操作:

  1. 依次点击 Help > Edit Custom Properties。如果您之前从未修改过 IDE 属性,Android Studio 将提示您新建一个 idea.properties 文件。点击 Yes 以创建文件。
  2. idea.properties 文件会在 Android Studio 的编辑器窗口中打开。修改该文件以添加您的自定义 IDE 属性。

以下 idea.properties 文件包括经常自定义的 IDE 属性。如需获得完整的属性列表,请参阅 IntelliJ IDEA 的 idea.properties 文件

#---------------------------------------------------------------------
# Uncomment this option if you want to customize path to user installed plugins folder. Make sure
# you're using forward slashes.
#---------------------------------------------------------------------
# idea.plugins.path=${idea.config.path}/plugins
#---------------------------------------------------------------------
# Maximum file size (kilobytes) IDE should provide code assistance for.
# The larger the file is, the slower its editor works and higher overall system memory requirements are
# if code assistance is enabled. Remove this property or set to very large number if you need
# code assistance for any files available regardless their size.
#---------------------------------------------------------------------
idea.max.intellisense.filesize=2500
#---------------------------------------------------------------------
# This option controls console cyclic buffer: keeps the console output size not higher than the
# specified buffer size (Kb). Older lines are deleted. In order to disable cycle buffer use
# idea.cycle.buffer.size=disabled
#---------------------------------------------------------------------
idea.cycle.buffer.size=1024
#---------------------------------------------------------------------
# Configure if a special launcher should be used when running processes from within IDE.
# Using Launcher enables "soft exit" and "thread dump" features.
#---------------------------------------------------------------------
idea.no.launcher=false
#---------------------------------------------------------------------
# To avoid too long classpath
#---------------------------------------------------------------------
idea.dynamic.classpath=false
#---------------------------------------------------------------------
# There are two possible values of idea.popup.weight property: "heavy" and "medium".
# If you have WM configured as "Focus follows mouse with Auto Raise", then you have to
# set this property to "medium". It prevents problems with popup menus on some
# configurations.
#---------------------------------------------------------------------
idea.popup.weight=heavy
#---------------------------------------------------------------------
# Use default anti-aliasing in system, i.e. override value of
# "Settings|Editor|Appearance|Use anti-aliased font" option. May be useful when using Windows
# Remote Desktop Connection for instance.
#---------------------------------------------------------------------
idea.use.default.antialiasing.in.editor=false
#---------------------------------------------------------------------
# Disabling this property may lead to visual glitches like blinking and fail to repaint
# on certain display adapter cards.
#---------------------------------------------------------------------
sun.java2d.noddraw=true
#---------------------------------------------------------------------
# Removing this property may lead to editor performance degradation under Windows.
#---------------------------------------------------------------------
sun.java2d.d3d=false
#---------------------------------------------------------------------
# Workaround for slow scrolling in JDK6.
#---------------------------------------------------------------------
swing.bufferPerWindow=false
#---------------------------------------------------------------------
# Removing this property may lead to editor performance degradation under X Window.
#---------------------------------------------------------------------
sun.java2d.pmoffscreen=false
#---------------------------------------------------------------------
# Workaround to avoid long hangs while accessing clipboard under Mac OS X.
#---------------------------------------------------------------------
# ide.mac.useNativeClipboard=True
#---------------------------------------------------------------------
# Maximum size (kilobytes) IDEA will load for showing past file contents -
# in Show Diff or when calculating Digest Diff.
#---------------------------------------------------------------------
# idea.max.vcs.loaded.size.kb=20480

针对低内存计算机配置 IDE

如需在低于建议规格(请参阅系统要求)的计算机上运行 Android Studio,可以按如下方式自定义 IDE 以提升计算机性能:

  • 减小 Android Studio 可用的堆大小上限:将 Android Studio 的堆大小上限减小至 512 MB。如需详细了解如何更改堆大小上限,请参阅堆大小上限
  • 更新 Gradle 和 Android Gradle 插件:更新至最新版本的 Gradle 和 Android Gradle 插件,以确保您能利用最新的性能改进。如需详细了解如何更新 Gradle 和 Android Gradle 插件,请参阅 Android Gradle 插件版本说明
  • 启用节能模式:启用节能模式会关闭一系列消耗大量内存和电量的后台操作,包括错误突出显示和动态检查、自动弹出式代码完成和自动增量式后台编译。如需开启节能模式,请依次点击 File > Power Save Mode
  • 停用不必要的 lint 检查:如需更改 Android Studio 在您的代码上运行的 lint 检查,请执行以下操作:

    1. 依次点击 File > Settings(在 macOS 上,依次点击 Android Studio > Preferences)以打开 Settings 对话框。
    2. 在左侧窗格中,展开 Editor 部分,然后点击 Inspections
    3. 点击相应的复选框以选中或取消选中适合项目的 lint 检查。
    4. 点击 ApplyOK 以保存所做的更改。
  • 在实体设备上调试:通过在实体设备上调试来提升 Android Studio 的总体性能。在模拟器上调试使用的内存比在实体设备上调试使用的内存更多。

  • 仅将必要的 Google Play 服务作为依赖项包含在内:仅将必要的 Google Play 服务作为依赖项包含在项目中。依赖项会增加所需的内存量,因此限制依赖项数量可提高内存利用率和性能。如需了解详情,请参阅声明 Google Play 服务的依赖项

  • 减少可用于 Gradle 的堆大小上限:Gradle 的默认堆大小上限为 1,536 MB,您可以通过替换 gradle.properties 文件中的 org.gradle.jvmargs 属性减小此值,如下所示:

    # Make sure to gradually decrease this value and note
    # changes in performance. Allocating too little memory can
    # also decrease performance.
    org.gradle.jvmargs = -Xmx1536m
    
  • 不要启用并行编译: Android Studio 可以并行编译独立模块,但如果您使用的是低内存系统,则不应启用此功能。如需检查此设置,请执行以下操作:

    1. 依次点击 File > Settings(在 macOS 上,依次点击 Android Studio > Preferences)以打开 Settings 对话框。
    2. 在左侧窗格中,展开 Build, Execution, Deployment,然后点击 Compiler
    3. 确保 Compile independent modules in parallel 选项未选中。
    4. 如果您进行了更改,请点击 ApplyOK 以使更改生效。

设置代理设置

代理作为 HTTP 客户端和网络服务器之间的中间连接点,可提高互联网连接的安全性和隐私性。

如需支持在防火墙后面运行 Android Studio,请使用 Android Studio IDE HTTP 代理设置页面设置 HTTP 代理设置。

若从命令行或在未安装 Android Studio 的计算机(例如持续集成服务器)上运行 Android Gradle 插件,请在 Gradle build 文件中设置代理设置。

设置 Android Studio 代理

Android Studio 支持 HTTP 代理设置,因此您可以在防火墙后面或使用安全网络运行 Android Studio。如需在 Android Studio 中设置 HTTP 代理设置,请执行以下操作:

  1. 在菜单栏中,依次点击 File > Settings(在 macOS 上,依次点击 Android Studio > Preferences)。
  2. 在左侧窗格中,依次点击 Appearance & Behavior > System Settings > HTTP Proxy。此时将显示 HTTP Proxy 页面。
  3. 选择 Auto-detect proxy settings 以使用自动代理配置网址配置代理设置,或选择 Manual proxy configuration 以自行输入每一项设置。有关这些设置的详细说明,请参阅 HTTP 代理
  4. 点击 Apply 或 OK 以保存所做的更改。

Android Plugin for Gradle HTTP 代理设置

若从命令行或在未安装 Android Studio 的计算机上运行 Android 插件,应在 Gradle build 文件中设置 Android Gradle 插件代理设置。

对于特定于应用的 HTTP 代理设置,请根据各应用模块的要求在 build.gradle 文件中设置代理设置:

plugins {
  id 'com.android.application'
}

android {
    ...

    defaultConfig {
        ...
        systemProp.http.proxyHost=proxy.company.com
        systemProp.http.proxyPort=443
        systemProp.http.proxyUser=userid
        systemProp.http.proxyPassword=password
        systemProp.http.auth.ntlm.domain=domain
    }
    ...
}

对于整个项目的 HTTP 代理设置,请在 gradle/gradle.properties 文件中设置代理设置:

# Project-wide Gradle settings.
...

systemProp.http.proxyHost=proxy.company.com
systemProp.http.proxyPort=443
systemProp.http.proxyUser=username
systemProp.http.proxyPassword=password
systemProp.http.auth.ntlm.domain=domain

systemProp.https.proxyHost=proxy.company.com
systemProp.https.proxyPort=443
systemProp.https.proxyUser=username
systemProp.https.proxyPassword=password
systemProp.https.auth.ntlm.domain=domain

...

如需了解如何使用 Gradle 属性进行代理设置,请参阅 Gradle 用户指南

在 Windows 上优化 Android Studio 性能

Windows 上的 Android Studio 性能可能会受多种因素的影响。 本节将介绍如何优化 Android Studio 设置以在 Windows 上获得最佳性能。

最大限度地降低杀毒软件对 build 运行速度的影响

某些防病毒软件会干扰 Android Studio 构建过程,从而导致 build 运行速度明显变慢。当您在 Android Studio 中运行 build 时,Gradle 会编译应用的资源和源代码,然后将编译后的资源打包在一个 APK 或 AAB 文件中。在此流程中,系统会在计算机上创建多个文件。如果您的杀毒软件启用了实时扫描功能,那么在每次创建一个文件后,杀毒软件都会扫描该文件,并强制要求暂停 build 流程。

如需避免此问题,您可以在杀毒软件中排除对某些目录的实时扫描。对于 Windows,Build Analyzer 可帮助您确定应从主动扫描中排除的目录并将其排除。

以下列表显示了您应从实时扫描中排除的每个 Android Studio 目录的默认位置:

Gradle 缓存
%USERPROFILE%\.gradle
Android Studio 项目
%USERPROFILE%\AndroidStudioProjects
Android SDK
%USERPROFILE%\AppData\Local\Android\SDK

Android Studio 系统文件

语法:%LOCALAPPDATA%\Google\<product><version>

示例:C:\Users\YourUserName\AppData\Local\Google\AndroidStudio4.1

为组策略受控环境自定义目录位置

如果组策略会限制您可以从计算机中排除实时扫描的目录,您可以将 Android Studio 目录移至集中式组策略已排除的某个位置。

以下列表显示了如何自定义每个 Android Studio 目录的位置,其中 C:\WorkFolder 是您的组策略已排除的目录:

Gradle 缓存
GRADLE_USER_HOME 环境变量定义为指向 C:\WorkFolder\.gradle
Android Studio 项目
将项目目录移到 C:\WorkFolder 的相应子目录中或在其中创建项目目录。例如: C:\WorkFolder\AndroidStudioProjects
Android SDK

若要自定义位置,请执行以下操作:

  1. 在 Android Studio 中,打开 Settings 对话框(在 macOS 上,打开 Preferences),然后依次转到 Appearance & Behavior > System Settings > Android SDK

  2. Android SDK Location 的值更改为 C:\WorkFolder\AndroidSDK

    为避免再次下载该 SDK,请确保将默认位于 %USERPROFILE%\AppData\Local\Android\SDK 下的现有 SDK 目录复制到新位置。

Android Studio 系统文件

若要自定义位置,请执行以下操作:

  1. 在 Android Studio 中,依次点击 Help > Edit Custom Properties

    Android Studio 会提示您创建一个 idea.properties 文件(如果尚未创建)。

  2. 将以下行添加到 idea.properties 文件中:

    idea.system.path=c:/workfolder/studio/caches/trunk-system