致命异常:java.lang.NoClassDefFoundError:android.support.v7.app.AppCompatDelegateImplV23

时间:2016-02-20 17:59:27

标签: android android-activity android-support-library appcompat-v7-r23

在我的最新版本中,我的一些用户(少于0.2%)因为找不到AppCompatDelegateImplV23.smali而崩溃。我无法重现这个问题,我只收到关于崩解的报道。我用apktool从我的apk中提取文件,我可以在那里看到compile 'com.android.support:appcompat-v7:23+' 。知道会发生什么吗?

这是我在gradle上的编译行:

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)

这是一个例外:

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:2.5.5@aar') {
        transitive = true;
    }


    compile 'com.github.navasmdc:MaterialDesign:1.+@aar'


    //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'


}

编辑:这是我的主要gradle文件:

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)

编辑:刚刚有一个新的报告,但同一个类的不同版本

AppCompatDelegateImplV23
编辑:我刚刚浏览了很多报告,其中一些是AppCompatDelegateImplV14,一些是c = database.rawQuery("UPDATE lesPlats SET quantite = 1 WHERE id = " + n, null); c.moveToFirst(); c.close(); ,有些是XPosed,但大部分没有。他们所有人都喜欢的一件事是,他们都是根植电话。

2 个答案:

答案 0 :(得分:3)

首先,我们需要了解为什么会出现 java.lang.NoClassDefFoundError 错误:

所以答案是当有一个代码所依赖的类文件时,它在编译时出现但在运行时没有找到。查找构建时间和运行时类路径的差异

因此,有一些选项可以删除此错误:

1)将preDexLibraries设为true:

Right click on your project -> "Open module settings" -> Dependencies tab -> check if Export is checked for your library

2)增量构建系统可能存在问题。因此,尝试从项目中删除构建文件夹并重建项目OR {{1}}

3)您需要做的不仅仅是提供 MultiDex支持

  • 你的defaultConfig块中的multiDexEnabled = true
  • 包括compile' com.android.support:multidex:1.0.0'在您的依赖项中
  • 让您的Application类扩展MultiDexApplication而不仅仅是Application。或者,您可以在应用程序的attachBaseContext()中调用MultiDex.install()

如需更多参考,您可以查看以下链接,该链接提供了对多语言的更深入理解。

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

4)或者最后您可以将V7的jar文件添加到项目的libs文件夹中,然后将其添加到您的构建系统中。

5)还尝试删除jar文件,因为它还包含 com.android.support:support-v4:23 + ,因为gradle有一个存储库它下载了类似于编译的jar文件' compile' com.android.support:appcompat-v7:23 +'

希望这可以为您提供一些关于错误的线索。

答案 1 :(得分:1)

我的猜测是问题是由于xposed框架造成的。在堆栈跟踪的底部,您可以发现受控框架启动了受精卵。

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

这意味着用户正在使用安装了xposed框架的自定义Android rom。该框架通常用于通过在运行时注入新代码来修改Android框架(以及任何应用程序)代码的行为。

您可以在https://github.com/rovo89/XposedBridge/tree/art/app/src/main/java/de/robv/android/xposed

查看其工作原理

由于代码行为可以在不同程度上改变,具体取决于通过xposed框架安装的mod,我无法确定异常的确切原因。但是,如果所有堆栈跟踪都以 XposedBrigde.main()开头,那么我可以说你的问题是由于暴露的框架或通过框架安装的mod。