Eclipse:Android项目中JDK类的java.lang.NoClassDefFoundError

时间:2013-01-03 03:11:59

标签: android eclipse adt noclassdeffounderror

首先,我想提一下,我读了很多有关 NoClassDefFoundError 的stackoverflow帖子,我也在很多其他博客中阅读了这篇文章。网站,但人们提供的解决方案没有解决它。

我在 Ubuntu 12.10 64位上使用ADT插件版本v21.0.1-543035运行 Eclipse 64位。一切都是64位,Ubuntu,Eclipse以及我使用的JRE和JDK(jdk1.6.0_38)。

我写了一个非常小的Android应用程序,需要JDK中的一个类才能运行。

我稍微隔离了这个问题,并通过创建一个新的“Android应用程序项目”来重新创建它,其中只有一行我的代码(在onCreate方法的主类中)。这一行:

  

BufferedImage buff = new BufferedImage(100,100,BufferedImage.TYPE_INT_RGB);

Eclipse会自动添加必要的导入:

  

import java.awt.image.BufferedImage;

但要求我为这个类添加jars / JRE。

我在“已安装的JRE”(like they instruct on the Eclipse help pages)中将jdk1.6.0_38添加到Eclipse。

在项目的“Java Build Path”中,我通过“Add library”添加了它 - > “JRE系统库” - > “工作区默认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)

以下是我尝试过的无效

  1. 添加“ 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参数”。
  3. 使用32位JRE和JDK以及JRE / JDK7 - 当然没有用。
  4. 我尝试将jdk jar文件手动添加到“libs”文件夹并标记“添加到buildpath” - 没有用。
  5. 我使用ADT和Android SDK再次卸载并安装了Eclipse ...
  6. 没有什么能解决这个烦人的错误......

    请注意这些:

    1. 我确保 .classpath 文件包含默认的JRE条目(like they say here
    2. 我尝试将其他 jar文件添加到“libs”文件夹+“添加到路径”,并使用它们 - 它工作正常。
    3. 我尝试使用“import java.awt.image.BufferedImage;”运行相同的代码(一行)在一个常规 java项目(不是一个Android项目)中,使项目“使用默认JRE” - 并且工作正常!为什么呢在REGULAR Java项目而不是在Android项目中工作?
    4. 我想这意味着我的Eclipse安装确实能够使用jdk类,但不在Android应用程序中

      那么我需要做些什么才能让这一行代码在Android应用程序中运行

      任何帮助都非常值得赞赏。提前完成。

1 个答案:

答案 0 :(得分:7)

  

那么我需要做些什么来使这一行代码在Android应用程序中运行?

简短的回答是:没有,因为你不能做任何事情。整个java.awt.*框架不是Android SDK的一部分,包括BufferedImage,因此模拟器或物理设备不支持。 Android有自己的加载和渲染图形的实现。

在不知道您需要BufferedImage的情况下,很难说您应该考虑哪种替代方案。您很可能尝试进行某种图像处理,包括访问图像的各个像素?如果是这种情况,请查看BitmapBitmapFactory类。

归结为Java SDK != Android SDK。无论如何,也考虑在这里搜索SO;你不是第一个犯这个错误的人。