Мгновенный запуск занимает больше времени, чем стандартные сборки
Прошло уже некоторое время, когда Instant Run больше не работает, то есть он медленнее, чем стандартные сборки.
В трекере ошибок AOSP есть какой-то материал, но я не смог разобраться. Я уверен, что некоторые из вас помогут.
Без мгновенного запуска
Сборки занимают около 1,30 мин.
С Мгновенным Бегом
Я запускаю приложение в первый раз, а затем внес некоторые незначительные изменения. Например, изменить int a = 1
в int a = 2
внутри метода или изменить строку.
Затем нажмите Run снова. Что просходит:
- На первый взгляд происходит полная сборка
assembleDebug
на всех моих модулях). Занимает около 1,30 мин. Второй раунд продолжается, просто позвонив
app:assembleDebug
, Это займет около минуты:16:27:10 Executing tasks: [:app:assembleDebug] 16:28:16 Gradle build finished in 1m 5s 264ms 16:28:22 Instant Run applied code changes and restarted the app.
Во время первого раунда не выводится вообще ни в журнал событий, ни в консоль Gradle. Во время второго раунда консоль Gradle выводит много материала и заканчивается
BUILD SUCCESSFUL
Total time: 51.385 secs
PREDEX CACHE HITS: 0
PREDEX CACHE MISSES: 45
Stopped 0 compiler daemon(s).
Что я могу сделать?
У меня есть это в моем grade.properties
файл:
org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8
org.gradle.parallel=true
org.gradle.daemon=true
Ничего декс не связано в build.gradle
файлы. Не использую Джека. Android Studio 2.2.3.
файл gradle.properties
org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8
org.gradle.parallel=true
org.gradle.daemon=true
ANDROID_BUILD_MIN_SDK_VERSION=15
ANDROID_BUILD_TARGET_SDK_VERSION=25
ANDROID_BUILD_SDK_VERSION=25
ANDROID_BUILD_TOOLS_VERSION=25.0.2
Уровень проекта build.gradle
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.2.3'
classpath 'com.google.gms:google-services:3.0.0'
}
}
allprojects {
repositories {
jcenter()
}
}
Основной модуль build.gradle
(У меня также есть два других "библиотечных" модуля)
apply plugin: 'com.android.application'
Properties signProp = new Properties()
signProp.load(new FileInputStream(file(project.property("SIGN_PROPS"))))
Properties authProp = new Properties()
authProp.load(new FileInputStream(file(project.property("AUTH_KEYS_PROPS"))))
def PARSE_APPLICATION_ID = '"' + authProp['parseApplicationId'] + '"';
def PARSE_CLIENT_KEY = '"' + authProp['parseClientKey'] + '"'
def PARSE_SERVER_URL = '"' + authProp['parseServerURL'] + '"'
def GOOGLE_PLAY_API_KEY = '"' + authProp['googlePlayApiKey'] + '"'
android {
signingConfigs {
release_config {
keyAlias signProp['keyAlias']
keyPassword signProp['keyPassword']
storeFile file(signProp['storeFilePath'])
storePassword signProp['storePassword']
}
}
compileSdkVersion Integer.parseInt(project.ANDROID_BUILD_SDK_VERSION)
buildToolsVersion project.ANDROID_BUILD_TOOLS_VERSION
defaultConfig {
minSdkVersion Integer.parseInt(project.ANDROID_BUILD_MIN_SDK_VERSION)
targetSdkVersion Integer.parseInt(project.ANDROID_BUILD_TARGET_SDK_VERSION)
versionCode 21
versionName "1.3.3"
buildConfigField 'String', 'PARSE_APPLICATION_ID', PARSE_APPLICATION_ID
buildConfigField 'String', 'PARSE_CLIENT_KEY', PARSE_CLIENT_KEY
buildConfigField 'String', 'PARSE_SERVER_URL', PARSE_SERVER_URL
buildConfigField 'String', 'GOOGLE_PLAY_API_KEY', GOOGLE_PLAY_API_KEY
signingConfig signingConfigs.release_config
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
vectorDrawables.useSupportLibrary = true
}
buildTypes {
release {
minifyEnabled true
shrinkResources true
}
debug {
minifyEnabled false
shrinkResources false
}
}
productFlavors {
}
}
dependencies {
compile 'com.android.support:design:24.2.1'
compile 'com.android.support:cardview-v7:24.2.1'
compile 'com.android.support:recyclerview-v7:24.2.1'
compile 'com.android.support:preference-v14:24.2.1'
compile 'com.google.maps.android:android-maps-utils:0.4.3'
compile 'com.google.android.gms:play-services-maps:9.2.1'
compile 'com.google.android.gms:play-services-appinvite:9.2.1'
compile 'com.google.android.gms:play-services-location:9.2.1'
compile 'com.google.android.gms:play-services-appindexing:9.2.1'
compile ('com.facebook.android:facebook-android-sdk:4.16.1') {
exclude module: 'bolts-tasks'
}
compile 'com.parse.bolts:bolts-tasks:1.4.0'
compile 'com.squareup.okhttp3:okhttp:3.2.0'
compile 'com.parse:parse-android:1.13.1'
compile ('com.parse:parseui-widget-android:0.0.1') {
exclude module: 'parse-android'
}
compile project(':dateTimePicker')
compile project(':commons')
}
apply plugin: 'com.google.gms.google-services'
4 ответа
http://tools.android.com/recent/androidstudio223isnowavailable
Обновите до последней версии Android Studio, а затем увеличьте профиль памяти в (studio.vmoptions) на основе вашей системной памяти.
-Xms256m
-Xmx1280m
-XX:MaxPermSize=350m
Включить мгновенный запуск
- Откройте диалоговое окно "Настройки" или "Настройки".
- Перейдите к Построить, Выполнение, Развертывание> Мгновенный запуск.
- установите флажок "Включить мгновенный запуск".
Ограничения Мгновенного Бега.
Развертывание на нескольких устройствах, мультидексирование приложения, использование сторонних плагинов, внесение изменений в многопроцессорные приложения, запуск приложения в рабочем профиле.
Если вы используете поддержку multidex (multiDexEnabled true) для своего приложения, minSdkVersion должно быть 21 или выше. В противном случае, Android Studio отключает Instant Run.
Плагин Android для Gradle версии должен быть 2.1.0 или выше
Включите Android-студию Offline Work для ускорения:
Зайдите в файл >> настройки или просто нажмите Ctrl + Alt + S
файл >> настройки >> Gradle. пожалуйста, проверьте автономную работу в настройках Global Gradle
Улучшение производительности Gradle
После открытия Android Studio откройте файл gradle.properties с правой стороны Android Studio и добавьте следующие две строки.
org.gradle.jvmargs=-Xmx1536m
org.gradle.daemon=true
org.gradle.parallel=true
Настроить варианты сборки отладки в buildTypes
debug {
minifyEnabled false
applicationIdSuffix ".debug"
}
После внесения изменений перезапустите Android Studio.
Примечание: время сборки зависит от вашего процессора и оперативной памяти. Я заметил в (i7-3610qm с оперативной памятью 8 ГБ), когда вы компилируете проект 4 android studio одновременно, а затем медленно реагируете на окно. после завершения процесса сборки ПК работает нормально.
Если вы используете сервисы Google Play, убедитесь, что вы не используете это в своем скрипте сборки Gradle:
compile 'com.google.android.gms:play-services:8.3.0'
Используйте только те API Google, которые действительно использует ваше приложение. Если все, что вы используете, это Google Maps, вы должны использовать это:
com.google.android.gms:play-services-maps:8.3.0
Когда я это сделал, время компиляции увеличилось с 2 минут до 25 секунд. Список API-интерфейсов Google, которые можно выборочно компилировать, см. В следующих разделах: