InnerClass 的 ClassNotFoundException 因为编译器以不同的方式生成类路径
ClassNotFoundException for InnerClass because Compiler generates classpath differently
我目前正在开发一个 Android 库模块。但是今天我们从 jvm.
收到了一个 st运行ge 错误
异常堆栈如下
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.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.access00(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.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.access00(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 似乎无法找到 class.
时抛出异常
// 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 包。 class FeedbackRepository$UpdateSentDatetimeAsyncTask.class 存在于适当的位置。
我们反编译了 FeedbackRepository.class 并查看了 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 实现并查看编译器是否正确编译它
- 删除整个项目并从存储库中克隆它。 (仍然出现错误)
重命名 class 时运行正常。将其重命名回所需的 class 名称但是重新创建了问题。
我们还能做什么?是否有我们需要删除的特定缓存?
编辑 1:
所以我们 运行 在不同的机器上构建。在这里它有效。但是有没有正确的方法来修复 Android-Studio 项目?
编辑 2:
刚刚删除了所有 .gradle/caches 无济于事
编辑 3:
重新安装 Android Studio 并在重新安装前删除了所有配置文件夹。我们仍然得到同样的错误。这真的很令人沮丧,因为这样的错误应该在一个项目到一个项目的基础上。这似乎成为一个全系统的问题是疯狂的,永远不应该发生。
我们还从防病毒扫描中排除了许多构建和缓存文件夹。
系统和安装信息:
- Windows 10
- Android Studio 3.5 测试版 5
好吧,这几乎是我们的错。
虽然代码分析和编译器也真的没有发出哔哔声!问题是我们有两次同名的内部 class!即'UpdateSentDatetimeAsyncTask'
奇怪的是没有人抱怨它。通常这种东西是由 IDE 或编译器报告的。不管怎样,现在已经修复了。
我目前正在开发一个 Android 库模块。但是今天我们从 jvm.
收到了一个 st运行ge 错误异常堆栈如下
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.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.access00(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.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.access00(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 似乎无法找到 class.
时抛出异常
// 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 包。 class FeedbackRepository$UpdateSentDatetimeAsyncTask.class 存在于适当的位置。
我们反编译了 FeedbackRepository.class 并查看了 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 实现并查看编译器是否正确编译它
- 删除整个项目并从存储库中克隆它。 (仍然出现错误)
重命名 class 时运行正常。将其重命名回所需的 class 名称但是重新创建了问题。
我们还能做什么?是否有我们需要删除的特定缓存?
编辑 1:
所以我们 运行 在不同的机器上构建。在这里它有效。但是有没有正确的方法来修复 Android-Studio 项目?
编辑 2:
刚刚删除了所有 .gradle/caches 无济于事
编辑 3:
重新安装 Android Studio 并在重新安装前删除了所有配置文件夹。我们仍然得到同样的错误。这真的很令人沮丧,因为这样的错误应该在一个项目到一个项目的基础上。这似乎成为一个全系统的问题是疯狂的,永远不应该发生。
我们还从防病毒扫描中排除了许多构建和缓存文件夹。
系统和安装信息:
- Windows 10
- Android Studio 3.5 测试版 5
好吧,这几乎是我们的错。
虽然代码分析和编译器也真的没有发出哔哔声!问题是我们有两次同名的内部 class!即'UpdateSentDatetimeAsyncTask'
奇怪的是没有人抱怨它。通常这种东西是由 IDE 或编译器报告的。不管怎样,现在已经修复了。