java.lang.VerifyError с API ‹ 21

Я использую MultiDex в своем приложении для поддержки более 65 000 методов. По сравнению с API 21 он работает хорошо, потому что он создает предварительную сборку. Под API 21 у меня происходит сбой в моем Application с этой трассировкой стека:

java.lang.VerifyError: mypackage/com/myapp/MyAppApplication
            at java.lang.Class.newInstanceImpl(Native Method)
            at java.lang.Class.newInstance(Class.java:1215)
            at android.app.Instrumentation.newApplication(Instrumentation.java:990)
            at android.app.Instrumentation.newApplication(Instrumentation.java:975)
            at android.app.LoadedApk.makeApplication(LoadedApk.java:502)
            at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4537)
            at android.app.ActivityThread.access$1500(ActivityThread.java:151)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1402)
            at android.os.Handler.dispatchMessage(Handler.java:110)
            at android.os.Looper.loop(Looper.java:193)
            at android.app.ActivityThread.main(ActivityThread.java:5322)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:829)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:645)
            at dalvik.system.NativeStart.main(Native Method)

Это мой файл gradle (упрощенный) с разными вариантами для компиляции с предварительным индексом в отладке:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 22
    buildToolsVersion "22.0.1"

    defaultConfig {
        applicationId "mypackage.com.myapp"
        targetSdkVersion 22
        versionCode Integer.parseInt(new Date().format("yyMMddHH"))
        versionName "1.0"
        multiDexEnabled = true
    }

    productFlavors {
        normal {
            minSdkVersion 21
        }

        beta {
            minSdkVersion 16
            versionName "1.0.0_beta"
        }

        prod {
            minSdkVersion 16
        }
    }

    dexOptions {
        javaMaxHeapSize "4g"
    }

    buildTypes {
        debug {
            minifyEnabled false
            debuggable true
        }
        release {
            minifyEnabled true
            shrinkResources true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    compile 'com.android.support:multidex:1.0.0'
}

А это мой Application:

public class MyApplication extends CustomLibraryApplication {
    @Override
    protected void attachBaseContext(Context base) {
        super.attachBaseContext(base);
        MultiDex.install(this);
    }
}

И в моем манифесте под <application> у меня есть android:name=".MyApplication"

Такие решения, как «исключить некоторые сервисы Google Play» или «расширить MultiDexApplication», в этом случае бесполезны.


person Giorgio Antonioli    schedule 23.07.2015    source источник
comment
Такие решения, как: исключить некоторые из сервисов Google Play или расширить MultiDexApplication, в этом случае бесполезны. - почему это не полезно? Я бы предложил запустить Proguard, чтобы избавиться от некоторых ваших лишних классов.   -  person Booger    schedule 23.07.2015
comment
@Booger исключает некоторые сервисы Google Play, потому что я знаю, как их исключить, но я хочу попробовать этот мультидекс-подход. расширить MultiDexApplication, потому что теперь я расширяю стороннюю библиотеку, которую не могу изменить. Я думал также запустить Proguard, но это будет последнее решение, прежде чем я хочу только понять, почему эта ошибка возникает, мне не нужно альтернативное решение. Мой вопрос состоял в том, чтобы лучше понять, как работает multidex.   -  person Giorgio Antonioli    schedule 23.07.2015


Ответы (2)


РЕШЕНО

Проблема была... в барабанной дроби... в buildToolsVersion!

Я изменил buildToolsVersion в своем градле (только buildToolsVersion) с 22.0.1 на 23 rc3 (последний из канала предварительного просмотра), и он хорошо работал с API ‹ 21 с мультидексом.

person Giorgio Antonioli    schedule 24.07.2015
comment
У меня это не сработало, я использую buildToolsVersion 28, я попытался перейти на 23 rc, но все равно не сработало, какую версию мне использовать. - person samuel owino; 24.01.2019

Другая проблема может быть, когда вы используете некоторые исключения библиотеки (для меня это было KeyPermanentlyInvalidated Exception), и это появилось только с API ‹21. Как только я изменил его на простой Exception, все стало нормально. Это мне отлично помогло https://stackoverflow.com/a/16060251/12258664

person Aleksey Kislyakov    schedule 22.10.2019