InnerClass的ClassNotFoundException,因为编译器生成的类路径不同

时间:2019-07-10 15:52:30

标签: android android-studio jvm classnotfoundexception inner-classes

我目前正在开发Android库模块。但是今天,jvm出现了一个奇怪的错误。

异常堆栈如下

E/FeedbackRepository: 'this' aufgerufen
D/AndroidRuntime: Shutting down VM
E/AndroidRuntime: FATAL EXCEPTION: main
    Process: ch.fhnw.edu.fcp.feedbackcommprocess, PID: 26531
    java.lang.NoClassDefFoundError: Failed resolution of: Lch/fhnw/edu/fcp/postcard/persistence/FeedbackRepository$UpdateSentDatetimeAsyncTask;
        at ch.fhnw.edu.fcp.postcard.persistence.FeedbackRepository.sendFeedback(FeedbackRepository.java:165)
        at ch.fhnw.edu.fcp.postcard.viewmodel.FeedbackViewModel.send(FeedbackViewModel.java:137)
        at ch.fhnw.edu.fcp.postcard.activity.TextSideActivity.sendFeedback(TextSideActivity.java:312)
        at ch.fhnw.edu.fcp.postcard.activity.TextSideActivity$4.onClick(TextSideActivity.java:107)
        at android.view.View.performClick(View.java:7352)
        at android.widget.TextView.performClick(TextView.java:14177)
        at android.view.View.performClickInternal(View.java:7318)
        at android.view.View.access$3200(View.java:846)
        at android.view.View$PerformClick.run(View.java:27800)
        at android.os.Handler.handleCallback(Handler.java:873)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:214)
        at android.app.ActivityThread.main(ActivityThread.java:7050)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:965)
     Caused by: java.lang.ClassNotFoundException: Didn't find class "ch.fhnw.edu.fcp.postcard.persistence.FeedbackRepository$UpdateSentDatetimeAsyncTask" on path: DexPathList[[zip file "/data/app/ch.fhnw.edu.fcp.feedbackcommprocess-86NmPv8EIZeWCEcZkVIMKw==/base.apk"],nativeLibraryDirectories=[/data/app/ch.fhnw.edu.fcp.feedbackcommprocess-86NmPv8EIZeWCEcZkVIMKw==/lib/arm64, /system/lib64, /system/vendor/lib64]]
        at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:134)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
        at ch.fhnw.edu.fcp.postcard.persistence.FeedbackRepository.sendFeedback(FeedbackRepository.java:165) 
        at ch.fhnw.edu.fcp.postcard.viewmodel.FeedbackViewModel.send(FeedbackViewModel.java:137) 
        at ch.fhnw.edu.fcp.postcard.activity.TextSideActivity.sendFeedback(TextSideActivity.java:312) 
        at ch.fhnw.edu.fcp.postcard.activity.TextSideActivity$4.onClick(TextSideActivity.java:107) 
        at android.view.View.performClick(View.java:7352) 
        at android.widget.TextView.performClick(TextView.java:14177) 
        at android.view.View.performClickInternal(View.java:7318) 
        at android.view.View.access$3200(View.java:846) 
        at android.view.View$PerformClick.run(View.java:27800) 
        at android.os.Handler.handleCallback(Handler.java:873) 
        at android.os.Handler.dispatchMessage(Handler.java:99) 
        at android.os.Looper.loop(Looper.java:214) 
        at android.app.ActivityThread.main(ActivityThread.java:7050) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:965) 
I/Process: Sending signal. PID: 26531 SIG: 9
Process 26531 terminated.

当我们尝试创建一个新的UpdateSentDatetimeAsyncTask时,抛出了异常,并且jvm似乎找不到该类。


// This is part of the FeedbackRepository class

public void sendFeedback(Feedback feedback) {
    Log.wtf("FeedbackRepsitory", "#sendFeedback called");
    new UpdateSentDatetimeAsyncTask(this.feedbackDAO).execute(feedback);

    // TODO: Networkservice.send(feedback)
}

// This is the InnerClass we want to instanciate
private static class UpdateSentDatetimeAsyncTask extends AsyncTask<Feedback, Void, Void> {

    private WeakReference<FeedbackDAO> mAsyncTaskDao;

    UpdateSentDatetimeAsyncTask(FeedbackDAO dao) { mAsyncTaskDao = new WeakReference<>(dao); }

    @Override
    protected Void doInBackground(final Feedback... params) {
        Feedback feedback = params[0];
        mAsyncTaskDao.get().updateSentDateTimeByUuid(new DateTime(), feedback.getUuid());
        return null;
    }
}

我们已经检查了演示应用程序中使用的.aar包中的.jar包。该类FeedbackRepository $ UpdateSentDatetimeAsyncTask.class存在于适当的位置。

我们已经反编译了FeedbackRepository.class,并在那里查看了该类的实例化。显然,我确实不知道如何解决该编译问题。

我提供了一个片段,其中我们几乎做了完全相同的事情,但是编译器生成了一些不同的东西。

public void sendFeedback(Feedback feedback) {
    // Here the compiler references the class by the full package path
    // This is the only place where it does it so I am blaming this
    // code generated code peace
    (new ch.fhnw.edu.fcp.postcard.persistence.FeedbackRepository.UpdateSentDatetimeAsyncTask(this.feedbackDAO)).execute(new Feedback[]{feedback});
}

public void delete(Feedback feedback) {
    // The inner class is referenced differently here
    // This code part works fine. Class is found.
    (new FeedbackRepository.DeleteFeedbackAsyncTask(this.feedbackDAO)).execute(new Feedback[]{feedback});
}

更多信息,我们已经尝试过
 -删除所有构建工件并重新构建整个解决方案
 -重新创建InnerClass实现,并查看编译器是否正确编译了
 -删除整个项目并从存储库中克隆它。 (仍然发生错误)

重命名该类时,它运行良好。将其重命名为所需的类名,却又重新创建了该问题。
我们还能做什么?有需要删除的特定缓存吗?

编辑1:
因此,我们在另一台机器上运行了构建。在这里工作。但是,有没有适当的方法来修复Android-Studio项目?

编辑2:
只是删除了所有.gradle / caches都没用

编辑3:
重新安装Android Studio并删除所有配置文件夹,然后重新安装。仍然我们得到同样的错误。确实令人沮丧,因为这样的错误应该发生在项目之间。看来这已成为系统性的问题,这是疯狂的,绝不应该发生。
我们还从防病毒扫描中排除了许多构建和缓存文件夹。

系统和安装信息:
-Windows 10
-Android Studio 3.5 Beta 5

1 个答案:

答案 0 :(得分:0)

好的,这几乎是我们的错。

尽管代码分析和编译器也没有对此发出哔哔声!问题是我们两次让内部类同名!那就是'UpdateSentDatetimeAsyncTask'

奇怪的是,没有人抱怨它。通常,这种东西是由IDE或编译器报告的。无论哪种方式,现在都已解决。