Проект здания: outOfMemory (студия Android 3.4) - PullRequest
2 голосов
/ 22 апреля 2019

Я обновил Android Studio 3.x до 3.4 (с плагином Grade), и теперь сборка моего проекта очень, очень, очень долгая, и есть последняя ошибка (после 4-5 минут сборки):

> Task :app:compileDevelopmentDebugJavaWithJavac
Gradle may disable incremental compilation as the following annotation processors are not incremental: butterknife-compiler-10.1.0.jar (com.jakewharton:butterknife-compiler:10.1.0), esperandro-2.6.0.jar (de.devland.esperandro:esperandro:2.6.0).
Consider setting the experimental feature flag android.enableSeparateAnnotationProcessing=true in the gradle.properties file to run annotation processing in a separate task and make compilation incremental.
Note: [1] Wrote GeneratedAppGlideModule with: [com.bumptech.glide.integration.okhttp3.OkHttpLibraryGlideModule]
warning: No SupportedSourceVersion annotation found on de.devland.esperandro.processor.EsperandroAnnotationProcessor, returning RELEASE_6.
warning: Supported source version 'RELEASE_6' from annotation processor 'org.gradle.api.internal.tasks.compile.processing.TimeTrackingProcessor' less than -source '1.8'


The system is out of resources.
Consult the following stack trace for details.
java.lang.OutOfMemoryError: GC overhead limit exceeded
    at java.lang.StringCoding$StringEncoder.encode(StringCoding.java:300)
    at java.lang.StringCoding.encode(StringCoding.java:344)

До этого обновления (сделано сегодня утром) все работает отлично.У вас есть какие-нибудь способы расследования, пожалуйста?

build.gradle:

buildscript {
    repositories {
        google()

        jcenter()
    }

    dependencies {
        // https://developer.android.com/studio/releases/gradle-plugin.html
        classpath 'com.android.tools.build:gradle:3.4.0'

        // https://developers.google.com/android/guides/google-services-plugin
        classpath 'com.google.gms:google-services:4.2.0'

        classpath 'com.google.firebase:firebase-plugins:1.2.0'

        // https://github.com/JakeWharton/butterknife
        classpath 'com.jakewharton:butterknife-gradle-plugin:10.1.0'
    }
}

gradle-wrappers.properties:

distributionUrl=https\://services.gradle.org/distributions/gradle-5.1.1-all.zip

Ответы [ 2 ]

0 голосов
/ 18 мая 2019

Попробуйте options.forkOptions.setMemoryMaximumSize ("2g") , если вы также используете options.fork.

Для меня org.gradle.jvmargs или javaMaxHeapSize не работает.Поэтому я закомментировал множество команд сценариев gradle для диагностики, вызывающих проблему, и обнаружил options.fork.

ps.Удаление options.fork также работает.

0 голосов
/ 22 апреля 2019

Увеличение объема памяти, доступной для системы сборки Gradle.

Поместите это в файл gradle.properties:

org.gradle.jvmargs=-Xmx2g

mx означает максимальный объем памяти, 2g означает два гигабайта.

Если уже есть org.gradle.jvmargs, добавьте -Xmx2g в конце.Удалите старую -Xmx, если она есть.

Для приложения не требуется более трех гигабайт.Добавление большего количества гигабайт не обязательно дает лучшую производительность.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...