Подтвердить что ты не робот

Fatal Exception: java.lang.NoClassDefFoundError: android.support.v7.app.AppCompatDelegateImplV23

В моей последней версии некоторые из моих пользователей (менее 0,2%) получают сбой, потому что android.support.v7.app.AppCompatDelegateImplV23 не может быть найден. Я не могу воспроизвести проблему, я получаю только сообщения о крахлитиках. Я использовал apktool для извлечения файлов из своего apk, и я вижу там AppCompatDelegateImplV23.smali. Любая идея, что может произойти?

Это моя строка компиляции на gradle:

compile 'com.android.support:appcompat-v7:23+'

Это исключение:

Fatal Exception: java.lang.NoClassDefFoundError: android.support.v7.app.AppCompatDelegateImplV23
       at android.support.v7.app.AppCompatDelegate.create(AppCompatDelegate.java:133)
       at android.support.v7.app.AppCompatDelegate.create(AppCompatDelegate.java:117)
       at android.support.v7.app.AppCompatActivity.getDelegate(AppCompatActivity.java:456)
       at android.support.v7.app.AppCompatActivity.onCreate(AppCompatActivity.java:59)
       at MyActivityClass.onCreate(MyActivityClass.java:353)
       at android.app.Activity.performCreate(Activity.java:6248)
       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1125)
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2437)
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2544)
       at android.app.ActivityThread.access$900(ActivityThread.java:150)
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1394)
       at android.os.Handler.dispatchMessage(Handler.java:102)
       at android.os.Looper.loop(Looper.java:168)
       at android.app.ActivityThread.main(ActivityThread.java:5845)
       at java.lang.reflect.Method.invoke(Method.java)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:797)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:687)
       at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:117)

EDIT: Это мой основной файл gradle:

buildscript {
    repositories {
        maven { url 'https://maven.fabric.io/public' }
        jcenter() // version plugin support

    }

    dependencies {
        classpath 'io.fabric.tools:gradle:1.+'
        classpath 'com.android.tools.build:gradle:1.3.1'

    }
    allprojects {
        repositories {
            jcenter()
        }
    }
}
apply plugin: 'com.android.application'
apply plugin: 'io.fabric'
apply plugin: 'com.google.gms.google-services'


repositories {
    maven { url 'https://maven.fabric.io/public' }
}


android {
    signingConfigs {
        config {
......
        }
    }
    compileSdkVersion 23
    buildToolsVersion "23.0.1"
    useLibrary 'org.apache.http.legacy'

    productFlavors {
        // Define separate dev and prod product flavors.
        dev {
            // dev utilizes minSDKVersion = 21 to allow the Android gradle plugin
            // to pre-dex each module and produce an APK that can be tested on
            // Android Lollipop without time consuming dex merging processes.
            minSdkVersion 21
        }
        prod {
            // The actual minSdkVersion for the application.
            minSdkVersion 14
        }
    }
    defaultConfig {
        applicationId "mypackage"
        minSdkVersion 14
        targetSdkVersion 23
        versionCode some number
        versionName "some version number"
        multiDexEnabled true
        signingConfig signingConfigs.config

    }


    buildTypes {
        release {
            minifyEnabled true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
            signingConfig signingConfigs.config
            applicationVariants.all { variant ->
                variant.outputs.each { output ->
                    output.outputFile = new File(output.outputFile.parent,"myapk.apk")

                }
            }
        }
        debug {
            signingConfig signingConfigs.config
        }

    }
    repositories {
        mavenCentral()
        mavenLocal()
    }
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_7
        targetCompatibility JavaVersion.VERSION_1_7

    }
    packagingOptions {
        exclude 'AndroidManifest.xml'
        exclude 'META-INF/beans.xml'
        exclude 'META-INF/LICENSE.txt'
        exclude 'META-INF/NOTICE.txt'
        exclude 'META-INF/LICENSE'
        exclude 'META-INF/NOTICE'
        exclude 'META-INF/DEPENDENCIES'
    }
    productFlavors {
    }
    dexOptions {
     //   preDexLibraries = false
        jumboMode = true
        javaMaxHeapSize "2g"
        //doesn't seem to be supported with multidex
       //   incremental true

    }
    lintOptions{
        disable 'MissingTranslation'
        disable 'ExtraTranslation'
    }
}

dependencies {

    compile fileTree(dir: 'libs', include: ['*.jar'])
    //multidex
    compile 'com.android.support:multidex:1.0.0'
    //support libs
    compile 'com.android.support:support-v4:23+'
    compile 'com.android.support:appcompat-v7:23+'
    compile 'com.android.support:cardview-v7:23+'
    compile 'com.android.support:design:23+'

    //app invites
    compile 'com.google.android.gms:play-services-appinvite:8+'

    compile 'com.google.android.gms:play-services-analytics:8+'
    //chromecast
    compile 'com.google.android.gms:play-services-cast:8+'
    compile 'com.android.support:mediarouter-v7:23+'

    //plus button
    compile 'com.google.android.gms:play-services-plus:8+'
    compile('com.crashlytics.sdk.android:crashlytics:[email protected]') {
        transitive = true;
    }


    compile 'com.github.navasmdc:MaterialDesign:[email protected]'


    //material lib needs it
    compile 'com.nineoldandroids:library:2.4.+'


    compile 'com.facebook.stetho:stetho:1+'
    compile 'com.facebook.stetho:stetho-okhttp:1+'



    //debugCompile 'com.squareup.leakcanary:leakcanary-android:1+'
    debugCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1+'
    releaseCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1+'

    compile 'com.makeramen:dragsortadapter:1.3+'

    compile 'com.github.amlcurran.showcaseview:library:5.0.0'


}

EDIT: просто появился новый отчет, но для другой версии того же класса

Fatal Exception: java.lang.NoClassDefFoundError: android.support.v7.app.AppCompatDelegateImplV14
       at android.support.v7.app.AppCompatDelegate.create(AppCompatDelegate.java:135)
       at android.support.v7.app.AppCompatDelegate.create(AppCompatDelegate.java:117)
       at android.support.v7.app.AppCompatActivity.getDelegate(AppCompatActivity.java:456)
       at android.support.v7.app.AppCompatActivity.onCreate(AppCompatActivity.java:59)
       at MyActivity.onCreate(MyActivity.java:353)
       at android.app.Activity.performCreate(Activity.java:5008)
       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2044)
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2105)
       at android.app.ActivityThread.access$600(ActivityThread.java:133)
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1211)
       at android.os.Handler.dispatchMessage(Handler.java:99)
       at android.os.Looper.loop(Looper.java:137)
       at android.app.ActivityThread.main(ActivityThread.java:4795)
       at java.lang.reflect.Method.invokeNative(Method.java)
       at java.lang.reflect.Method.invoke(Method.java:511)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
       at dalvik.system.NativeStart.main(NativeStart.java)

EDIT: я только что просмотрел много отчетов, некоторые для AppCompatDelegateImplV23, а некоторые для AppCompatDelegateImplV14, некоторые из них относятся к XPosed, но большинство из них этого не делают. Единственное, что является общим для всех из них, это то, что все они предназначены для укоренившихся телефонов.

4b9b3361

Ответ 1

Прежде всего, нам нужно понять, почему возникает ошибка java.lang.NoClassDefFoundError:

Итак, ответ заключается в том, что когда есть файл класса, от которого зависит ваш код, и он присутствует во время компиляции, но не найден во время выполнения. Ищите различия в времени сборки и пути к классам времени выполнения.

Таким образом, есть некоторые опции, позволяющие удалить эту ошибку:

1) Сделайте preDexLibraries истинным:

 dexOptions {
        preDexLibraries = true
        jumboMode = true
        javaMaxHeapSize "2g"
        //doesn't seem to be supported with multi dex
       //   incremental true
    }

2) Может возникнуть проблема с системой инкрементной сборки. Поэтому попробуйте удалить папку с вашим проектом из проекта и перестроить проект OR Right click on your project -> "Open module settings" -> Dependencies tab -> check if Export is checked for your library

3) Вам нужно сделать больше, чем просто предоставить поддержку MultiDex.

  • multiDexEnabled = true в блоке defaultConfig
  • Включить компиляцию 'com.android.support:multidex:1.0.0' в ваши зависимости
  • Пусть ваш класс приложения расширяет MultiDexApplication вместо приложения. Кроме того, вы можете вызвать MultiDex.install() в attachBaseContext() вашего приложения

Для получения дополнительной информации вы можете проверить приведенную ниже ссылку, которая обеспечила более глубокое понимание multi dex.

https://developer.android.com/tools/building/multidex.html

4) Или, наконец, вы можете добавить файлы jar файла V7 в папку с вашими проектами, а затем добавить его в свою систему сборки.

5) Также попробуйте удалить файлы jar, а также включить com.android.support:support-v4:23 +, поскольку gradle имеет репозиторий, где он загружает jars delcared как compile 'compile' com.android.support:appcompat-v7:23 + '

Надеюсь, это может дать вам некоторые сведения о вашей ошибке.

Ответ 2

Я предполагаю, что проблема связана с xposed framework. В нижней части трассировки стека вы можете обнаружить, что зигота была запущена инфраструктурой xposed.

   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:687)
   at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:117)

Это означает, что пользователь использует пользовательский ролик Android с установленной инфраструктурой xposed. Структура обычно используется для изменения поведения кода Android (и любого приложения, конечно) путем ввода нового кода во время выполнения.

Вы можете проверить, как это работает: https://github.com/rovo89/XposedBridge/tree/art/app/src/main/java/de/robv/android/xposed

Так как поведение кода может быть изменено в различной степени в зависимости от того, какие мода установлены через xposed framework, я не могу точно определить точную причину вашего исключения. Однако, если все трассировки стека начинаются с XposedBrigde.main(), я могу сказать, что ваша проблема связана с открытой каркасом или модами, установленными через фреймворк.