首先,我想提一下,我阅读了许多关于NoClassDefFoundError的stackoverflow 帖子,并且我还在许多其他博客和网站上阅读了它,但人们提供的解决方案并没有解决它。
我在Ubuntu 12.10 64-bit上运行带有 ADT 插件版本 v21.0.1-543035 的Eclipse 64 -bit 。一切都是 64 位的,Ubuntu、Eclipse 以及我使用的 JRE 和 JDK (jdk1.6.0_38)。
我编写了一个非常小的 Android 应用程序,它需要 JDK 中的一个类才能运行。
我稍微隔离了这个问题,并通过创建一个新的“Android 应用程序项目”来重新创建它,其中只有一行我的代码(在 onCreate 方法的主类中)。这一行:
BufferedImage buff = new BufferedImage(100,100,BufferedImage.TYPE_INT_RGB);
Eclipse 自动添加必要的导入:
导入 java.awt.image.BufferedImage;
但要求我为这个类添加 jars/JRE。
我在“已安装的 JRE”中将 jdk1.6.0_38 添加到 Eclipse(就像他们在 Eclipse 帮助页面上指示的那样)。
在项目的“Java Build Path”中,我通过“Add library”->“JRE system library”->“Workspace default JRE”添加了它。它自动将 JDK 添加到项目的构建路径中。
在编译期间,我没有收到任何错误。只有在 android 模拟器(任何 AVD)中运行应用程序时,我才会收到以下错误:
E/dalvikvm(828): Could not find class 'java.awt.image.BufferedImage', referenced from method com.example.usejdk.MainActivity.onCreate
W/dalvikvm(828): VFY: unable to resolve new-instance 467 (Ljava/awt/image/BufferedImage;) in Lcom/example/usejdk/MainActivity;
D/dalvikvm(828): VFY: replacing opcode 0x22 at 0x0009
D/dalvikvm(828): DexOpt: unable to opt direct call 0x0cdc at 0x0c in Lcom/example/usejdk/MainActivity;.onCreate
D/AndroidRuntime(828): Shutting down VM
W/dalvikvm(828): threadid=1: thread exiting with uncaught exception (group=0x40a70930)
E/AndroidRuntime(828): FATAL EXCEPTION: main
E/AndroidRuntime(828): java.lang.NoClassDefFoundError: java.awt.image.BufferedImage
E/AndroidRuntime(828): at com.example.usejdk.MainActivity.onCreate(MainActivity.java:16)
E/AndroidRuntime(828): at android.app.Activity.performCreate(Activity.java:5104)
E/AndroidRuntime(828): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
E/AndroidRuntime(828): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
E/AndroidRuntime(828): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
E/AndroidRuntime(828): at android.app.ActivityThread.access$600(ActivityThread.java:141)
E/AndroidRuntime(828): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
E/AndroidRuntime(828): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(828): at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime(828): at android.app.ActivityThread.main(ActivityThread.java:5039)
E/AndroidRuntime(828): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(828): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime(828): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
E/AndroidRuntime(828): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
E/AndroidRuntime(828): at dalvik.system.NativeStart.main(Native Method)
以下是我尝试但不起作用的事情:
- 在“ eclipse.ini ”中添加 jdk 的位置(“-vm /usr/lib/jvm/jdk1.6.0_38/bin”在 2 个单独的行中)。
- 我添加了路径“-Djava.library.path=/usr/lib/jvm/jdk1.6.0_38/jre/lib”的“默认 VM 参数”。
- 使用 32 位 JRE 和 JDK 以及 JRE/JDK7 - 不起作用(当然)。
- 我尝试将 jdk jar 文件手动添加到“libs”文件夹并标记“添加到 buildpath” - 没有用。
- 我使用 ADT 和 Android SDK 再次卸载并安装了 Eclipse ......
没有什么能解决这个烦人的错误......
请同时注意这些:
- 我确保我的.classpath文件包含默认的 JRE 条目(就像他们在这里说的那样)
- 我尝试将其他jar 文件添加到“libs”文件夹+“添加到路径”,并使用它们 - 它工作正常。
- 我尝试使用“import java.awt.image.BufferedImage;”运行相同的代码(一行)在一个常规的java 项目(不是一个 android 项目)中,并使项目“使用默认 JRE”——它工作得很好!为什么它适用于常规 Java 项目而不适用于 Android 项目?
我想这意味着我的 Eclipse 安装确实能够使用 jdk 类,但不能在 android applications 中使用。
那么我必须做些什么才能让这行代码在 android 应用程序中运行呢?
非常感谢任何帮助。提前谢谢。