Java 使用jack android重新部署后,ClassNotFoundException与生成的类

Java 使用jack android重新部署后,ClassNotFoundException与生成的类,java,android,classnotfoundexception,auto-generate,generated-code,Java,Android,Classnotfoundexception,Auto Generate,Generated Code,我正在创建一个应用程序,其中库为我生成SQL数据库和内容提供商。我还使用了其他一些库,我将在底部包含我的gradle文件 当我首先部署应用程序时,它会正确运行,但如果我更改代码中的某些内容(即使只是插入日志)并重新部署应用程序,它会在启动时崩溃,但出现以下异常: 02-08 20:53:40.279 29400-29400/hu.bendaf.udacity.popularmovies.popularmoviesapp E/AndroidRuntime: FATAL EXCEPTION: mai

我正在创建一个应用程序,其中库为我生成SQL数据库和内容提供商。我还使用了其他一些库,我将在底部包含我的gradle文件

当我首先部署应用程序时,它会正确运行,但如果我更改代码中的某些内容(即使只是插入日志)并重新部署应用程序,它会在启动时崩溃,但出现以下异常:

02-08 20:53:40.279 29400-29400/hu.bendaf.udacity.popularmovies.popularmoviesapp E/AndroidRuntime: FATAL EXCEPTION: main
    Process: hu.bendaf.udacity.popularmovies.popularmoviesapp, PID: 29400
    java.lang.RuntimeException: Unable to get provider hu.bendaf.udacity.popularmovies.popularmoviesapp.data.generated.MovieProvider: java.lang.ClassNotFoundException: Didn't find class "hu.bendaf.udacity.popularmovies.popularmoviesapp.data.generated.MovieProvider" on path: DexPathList[[zip file "/data/app/hu.bendaf.udacity.popularmovies.popularmoviesapp-1/base.apk"],nativeLibraryDirectories=[/data/app/hu.bendaf.udacity.popularmovies.popularmoviesapp-1/lib/arm64, /system/lib64, /vendor/lib64]]
    at android.app.ActivityThread.installProvider(ActivityThread.java:5856)
    at android.app.ActivityThread.installContentProviders(ActivityThread.java:5445)
    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5384)
    at android.app.ActivityThread.-wrap2(ActivityThread.java)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1545)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:154)
    at android.app.ActivityThread.main(ActivityThread.java:6119)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)
Caused by: java.lang.ClassNotFoundException: Didn't find class "hu.bendaf.udacity.popularmovies.popularmoviesapp.data.generated.MovieProvider" on path: DexPathList[[zip file "/data/app/hu.bendaf.udacity.popularmovies.popularmoviesapp-1/base.apk"],nativeLibraryDirectories=[/data/app/hu.bendaf.udacity.popularmovies.popularmoviesapp-1/lib/arm64, /system/lib64, /vendor/lib64]]
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:380)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
    at android.app.ActivityThread.installProvider(ActivityThread.java:5841)
    at android.app.ActivityThread.installContentProviders(ActivityThread.java:5445) 
    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5384) 
    at android.app.ActivityThread.-wrap2(ActivityThread.java) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1545) 
    at android.os.Handler.dispatchMessage(Handler.java:102) 
    at android.os.Looper.loop(Looper.java:154) 
    at android.app.ActivityThread.main(ActivityThread.java:6119) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776) 
MovieProvider类应该与schematic库一起生成(它在第一次部署时生成,但由于某种原因在部署后消失)

如果我清理了项目,我可以重新正确部署和运行我的应用程序,但每次修改后清理项目是非常烦人的。:)

您能帮我解决问题的原因吗?

这是我的build.gradle文件:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 25
    buildToolsVersion "25.0.2"
    defaultConfig {
        applicationId "hu.bendaf.udacity.popularmovies.popularmoviesapp"
        minSdkVersion 15
        targetSdkVersion 25
        versionCode 2
        versionName "1.1"
        vectorDrawables.useSupportLibrary = true
        jackOptions {
            enabled true
        }
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
    compileOptions {
        targetCompatibility 1.8
        sourceCompatibility 1.8
    }
}

repositories {
    mavenCentral()
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.android.support', module: 'support-annotations'
    })
    compile 'com.android.support:appcompat-v7:25.1.1'
    compile 'com.squareup.picasso:picasso:2.5.2'
    compile 'com.android.support:design:25.1.1'
    compile 'com.google.code.gson:gson:2.4'
    compile 'com.squareup.retrofit2:retrofit:2.1.0'
    compile 'com.squareup.retrofit2:converter-gson:2.0.2'
    compile 'com.android.support.constraint:constraint-layout:1.0.0-beta4'
    compile 'com.jakewharton:butterknife:8.5.1'
    annotationProcessor 'com.jakewharton:butterknife-compiler:8.5.1'
    compile 'com.android.support:recyclerview-v7:25.1.1'
    compile 'com.android.support:cardview-v7:25.1.1'
    annotationProcessor 'net.simonvt.schematic:schematic-compiler:0.7.0'
    compile 'net.simonvt.schematic:schematic:0.7.0'
}

你可以在

上找到我的整个项目,这可能是因为ProGuard进行了缩小。您必须手动指定以忽略外部库的缩小

您可以像这样在
proguard rules.pro
文件中指定它

-keep class com.package.** { *; }

阅读更多..

我解决了这个问题,因为我使用了jack和java 1.8。在我从gradle中删除这些行(以及应用程序中的lambda函数)后,崩溃消失了:

jackOptions {
    enabled true
}
...
compileOptions {
    targetCompatibility 1.8
    sourceCompatibility 1.8
}

谢谢你的帮助

嗨,我在udacity上做了(几乎)相同的应用程序。我用了图解法,效果很好。为什么在原理图编译器库的gradle文件中使用“annotationProcessor”而不是“compile”?(我用了“编译”)。你试过修改吗?我刚从原理图库的自述文件中复制了这两行。我也用compile试过了,但没有解决问题:(我把它放在proguard-rules.pro文件中,但没有解决问题:(
-keep class hu.bendaf.udacity.popularmovies.popularmoviesapp.data.generated.*{*}
添加这个
-keep class hu.bendaf.udacity.*{*}
也可以在其他外部库中使用。此外,您应该保留
com.android
中的类。仍然是相同的崩溃,我很抱歉:'(