Android Studio 提供诸多向导和模板,可用于验证系统要求(例如 Java 开发工具包 (JDK) 和可用 RAM)和配置默认设置(例如经过优化的默认 Android Virtual Device (AVD) 模拟和更新后的系统映像)。本文档介绍了您可能需要使用的其他配置设置,以便您自定义对 Android Studio 的使用方式。
您可以通过 Android Studio 的 Help 菜单访问下面这两个配置文件:
studio.vmoptions
:自定义 Studio 的 Java 虚拟机 (JVM) 选项,例如堆大小和缓存大小。请注意,在 Linux 计算机上,此文件可能会命名为 studio64.vmoptions
,具体取决于您的 Android Studio 版本。idea.properties
:自定义 Android Studio 的属性,例如插件文件夹路径或支持的文件大小上限。如需模拟器和设备的设置及使用方式的相关文档,请参阅以下主题:
两个配置文件都存储在 Android Studio 的配置文件夹中。文件夹名称取决于您的 Studio 版本。例如,Android Studio 3.3 的文件夹名称为 AndroidStudio3.3
。此文件夹的位置取决于您的操作系统:
%USERPROFILE%\.CONFIGURATION_FOLDER
~/Library/Preferences/CONFIGURATION_FOLDER
~/.CONFIGURATION_FOLDER
您也可以使用以下环境变量指向其他位置的特定替换文件:
STUDIO_VM_OPTIONS
:设置 .vmoptions
文件的名称和位置STUDIO_PROPERTIES
:设置 .properties
文件的名称和位置STUDIO_JDK
:设置运行 Studio 所使用的 JDK通过 studio.vmoptions
文件,您可以自定义 Android Studio 的 JVM 的选项。为了提高 Studio 的性能,最常用的调节选项是最大堆大小,但您也可以使用 studio.vmoptions
文件替换其他默认设置(例如初始堆大小、缓存大小和 Java 垃圾回收开关)。
要创建新的 studio.vmoptions
文件或打开现有文件,请按以下步骤操作:
studio.vmoptions
文件。点击 Yes 以创建文件。studio.vmoptions
文件会在 Android Studio 的编辑器窗口中打开。修改该文件以添加您自己的自定义虚拟机选项。如需可自定义 JVM 选项的完整列表,请参阅 Oracle 的 Java HotSpot 虚拟机选项页面。您创建的 studio.vmoptions
文件将添加到默认的 studio.vmoptions
文件中,后者位于 Android Studio 安装文件夹内的 bin/
目录中。
请注意,切勿直接修改 Android Studio 程序文件夹内的 studio.vmoptions
文件。尽管您可以访问该文件来查看 Studio 的默认虚拟机选项,但仅修改自己的 studio.vmoptions
文件可确保您不会替换 Android Studio 的重要默认设置。因此,在您的 studio.vmoptions
文件中,请仅替换您关注的属性,以便 Android Studio 可继续为您未更改的所有属性使用默认值。
默认情况下,Android Studio 的最大堆大小为 1280MB。如果您处理的是大项目,或者您的系统有大量 RAM 可用,您可以通过增大 Android Studio 进程(例如核心 IDE、Gradle 守护进程和 Kotlin 守护进程)的最大堆大小来提升性能。
Android Studio 会自动检查可采取的堆大小优化措施,并在检测到性能可以提升时通知您。
如果您使用的是 64 位系统并配有不少于 5 GB 的 RAM,您还可以手动调整项目的堆大小。为此,请按以下步骤操作:
依次点击 Appearance & Behavior > System Settings > Memory Settings。
调整堆大小以匹配所需的容量。
点击 Apply。
如果您更改了 Android Studio 的堆大小,则必须重启 Android Studio 才能让新的内存设置生效。
注意:分配过多内存会降低性能。
您可以导出一个 Settings.jar
文件,其中包含项目的全部或部分首选 IDE 设置。然后,您可以将该 JAR 文件导入其他项目,并/或将该文件共享给同事,以便他们将其导入到自己的项目中。
如需了解详情,请参阅 IntelliJ IDEA 中的导出和导入设置。
通过 idea.properties
文件,您可以自定义 Android Studio 的 IDE 属性,例如用户所安装插件的路径以及 Android Studio 支持的文件大小上限。idea.properties
文件会与 Android Studio 的默认属性合并,以便您可以仅指定要替换的属性。
要创建新的 idea.properties
文件或打开现有文件,请按以下步骤操作:
idea.properties
文件。点击 Yes 以创建文件。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 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
如果您要在低于建议规格(请参阅系统要求)的计算机上运行 Android Studio,则可以按如下方式自定义 IDE 以提升计算机性能:
停用不必要的 lint 检查:要更改 Android Studio 在您的代码上运行的 lint 检查,请执行以下操作:
在实体设备上调试:在模拟器上调试使用的内存比在实体设备上调试使用的内存更多,因此您可以通过在实体设备上调试来提升 Android Studio 的总体性能。
仅将必要的 Google Play 服务作为依赖项包含在内:将 Google Play 服务作为依赖项包含在项目中会增加所需的内存量。仅添加必要的依赖项以提高内存利用率和性能。如需了解详情,请参阅将 Google Play 服务添加到您的项目中。
开启 Gradle 的离线模式:如果您的带宽有限,请开启离线模式,以防 Gradle 在您编译期间尝试下载缺失的依赖项。离线模式开启时,Gradle 会在您缺少任何依赖项时发出编译故障,而不会尝试下载它们。要开启离线模式,请执行以下操作:
减少可用于 Gradle 的最大堆大小:Gradle 的默认最大堆大小为 1536 MB。您可以通过替换 gradle.properties
文件中的 org.gradle.jvmargs
属性来减小此值,如下所示:
# Make sure to gradually decrease this value and note
# changes in performance. Allocating too lttle memory may
# also decrease performance.
org.gradle.jvmargs = -Xmx1536m
不要启用并行编译:Android Studio 可以并行编译独立模块,但如果您使用的是低内存系统,则不应启用此功能。要检查此设置,请执行以下操作:
Android Studio 2.2 及更高版本捆绑提供了最新版本的 OpenJDK,这是我们建议用于 Android 项目的 JDK 版本。要使用捆绑的 JDK,请执行以下操作:
默认情况下,用于编译项目的 Java 语言版本基于项目的 compileSdkVersion
(因为不同版本的 Android 支持不同版本的 Java)。如有必要,您可以通过将以下 CompileOptions {}
代码块添加到 build.gradle
文件来替换此默认 Java 版本:
android {
compileOptions {
sourceCompatibility JavaVersion.VERSION\_1\_6
targetCompatibility JavaVersion.VERSION\_1\_6
}
}
如需详细了解 compileSdkVersion
在何处定义,请参阅模块级构建文件。
代理作为 HTTP 客户端和网络服务器之间的中间连接点,可提高互联网连接的安全性和隐私性。
要支持在防火墙后面运行 Android Studio,请为 Android Studio IDE 设置代理设置。使用 Android Studio IDE HTTP 代理设置页面可为 Android Studio 设置 HTTP 代理设置。
若从命令行或在未安装 Android Studio 的计算机(例如持续集成服务器)上运行 Android Plugin for Gradle,请在 Gradle 编译文件中设置代理设置。
注意:在初始安装 Android Studio 软件包后,可通过在线或离线的方式运行 Android Studio。不过,Android Studio 需要互联网连接才能执行设置向导同步、第三方库访问、访问远程代码库、Gradle 初始化和同步以及 Android Studio 版本更新。
Android Studio 支持 HTTP 代理设置,因此您可以在防火墙后面或使用安全网络运行 Android Studio。要在 Android Studio 中设置 HTTP 代理设置,请执行以下操作:
若从命令行或在未安装 Android Studio 的计算机上运行 Android 插件,则应在 Gradle 编译文件中设置 Android Plugin for Gradle 代理设置。
对于特定于应用的 HTTP 代理设置,请根据各应用模块的要求在 build.gradle
文件中设置代理设置。
apply plugin: '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 用户指南。
注意:在使用 Android Studio 时,Android Studio IDE HTTP 代理设置页面中的设置将替换
gradle.properties
文件中的 HTTP 代理设置。
Windows 上的 Android Studio 性能可能会受多种因素的影响。本节将介绍如何优化 Android Studio 设置以在 Windows 上获得最佳性能。
某些防病毒软件会干扰 Android Studio 编译流程,从而导致编译版本运行速度明显变慢。当您在 Android Studio 中运行编译版本时,Gradle 会编译应用的资源和源代码,然后将编译后的资源打包在一个 APK 中。在此流程中,系统会在计算机上创建多个文件。如果您的防病毒软件启用了实时扫描功能,那么在每次创建一个文件后,防病毒软件都会扫描该文件,并强制要求暂停编译流程。
要避免此问题,您可以在防病毒软件中排除对某些目录的实时扫描。
注意:为了确保计算机免受恶意软件的侵扰,您不应完全停用实时扫描或防病毒软件。
以下列表显示了您应从实时扫描中排除的每个 Android Studio 目录的默认位置:
Gradle 缓存
%USERPROFILE%\.gradle
Android Studio 项目
%USERPROFILE%\AndroidStudioProjects
Android SDK
%USERPROFILE%\AppData\Local\Android\SDK
Android Studio 系统文件
%USERPROFILE%\.AndroidStudio
为组策略受控环境自定义目录位置
如果组策略会限制您可以从计算机中排除实时扫描的目录,您可以将 Android Studio 目录移至集中式组策略已排除的某个位置。
以下列表显示了如何自定义每个 Android Studio 目录的位置,其中 C:\WorkFolder
是您的组策略已排除的目录:
Gradle 缓存
将 GRADLE_USER_HOME
环境变量定义为指向C:\WorkFolder\.gradle
。
Android Studio 项目
将项目目录移到 C:\WorkFolder
的相应子目录中或在其中创建项目目录。例如:C:\WorkFolder\AndroidStudioProjects
。
Android SDK
请按以下步骤操作:
在 Android Studio 中,打开 Settings 对话框(在 macOS 上,打开 Preferences),然后依次转到 Appearance & Behavior > System Settings > Android SDK。
将 Android SDK Location 的值更改为 C:\WorkFolder\AndroidSDK
。
为避免再次下载该 SDK,请确保将默认位于 %USERPROFILE%\AppData\Local\Android\SDK
下的现有 SDK 目录复制到新位置。
Android Studio 系统文件
请按以下步骤操作:
在 Android Studio 中,依次点击 Help > Edit Custom Properties。
Android Studio 会提示您创建一个 idea.properties
文件(如果尚未创建)。
将以下行添加到 idea.properties
文件中:
idea.system.path=c:/workfolder/studio/caches/trunk-system
如果您想在没有网络连接的情况下编译项目,请按照以下步骤配置 Android Studio,以使用 Android Gradle 插件和 Google Maven 依赖项的离线版本。
如果您尚未下载的话,请从下载页面下载离线组件。
下载离线组件后,将其内容解压缩到以下目录中,如果该目录尚不存在,您可能需要创建该目录:
%USER_HOME%/.android/manual-offline-m2/
~/.android/manual-offline-m2/
要更新离线组件,请按以下步骤操作:
manual-offline-m2/
目录中的内容。manual-offline-m2/
目录中。要告知 Android 编译系统使用您已下载并解压缩的离线组件,您需要创建一个脚本(如下所述)。请注意,即使在更新离线组件之后,您也只需创建并保存此脚本一次。
%USER_HOME%/.gradle/init.d/offline.gradle
~/.gradle/init.d/offline.gradle
打开该文本文件并添加以下脚本:
def reposDir = new File(System.properties['user.home'], ".android/manual-offline-m2")
def repos = new ArrayList()
reposDir.eachDir {repos.add(it) }
repos.sort()
allprojects {
buildscript {
repositories {
for (repo in repos) {
maven {
name = "injected_offline_${repo.name}"
url = repo.toURI().toURL()
}
}
}
}
repositories {
for (repo in repos) {
maven {
name = "injected_offline_${repo.name}"
url = repo.toURI().toURL()
}
}
}
}
保存该文本文件。
(可选)如果您想要验证离线组件是否运行正常,请从项目的 build.gradle
文件中移除在线代码库(如下所示)。在确认项目不使用这些代码库也能正确编译之后,您可以将它们放回到 build.gradle
文件中。
buildscript {
repositories {
// Hide these repositories to test your build against
// the offline components. You can include them again after
// you've confirmed that your project builds ‘offline’.
// google()
// jcenter()
}
...
}
allprojects {
repositories {
// google()
// jcenter()
}
...
}
注意:此脚本会影响您在工作站上打开的所有 Gradle 项目。