0

java.lang.NoClassDefFoundError

我有一个依赖于两个 jar 文件的 java 程序。我使用命令编译程序:

javac -classpath jar1.jar:jar2.jar myprog.java并且编译成功。

但是当我尝试使用命令运行程序时:java -cp jar1.jar:jar2.jar myprog,它正在抛出java.lang.NoClassDefFoundError. 请帮忙,我哪里错了?

我正在使用 ubuntu 10.04。

实际错误:

Exception in thread "main" java.lang.NoClassDefFoundError: userapps/SelectionTask_classes/SelectionTask
Caused by: java.lang.ClassNotFoundException: userapps.SelectionTask_classes.SelectionTask
    at java.net.URLClassLoader$1.run(URLClassLoader.java:217)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:321)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
Could not find the main class: userapps/SelectionTask_classes/SelectionTask. Program will exit.

其中 SelectionTask 是我编译成功后生成的类文件。

4

3 回答 3

1

确保当前目录也在类路径中。尝试运行:

java -cp .:jar1.jar:jar2.jar myprog

如果您编译的类文件myprog.class在当前目录中。

(这假设您的程序不在包中)。

于 2012-02-09T13:33:40.750 回答
0

您需要添加已编译的 java 程序 (*.class) 文件所在的目录。如果它在当前目录中,那么您可以像这样运行它(注意“。”表示当前工作目录):

java -cp .:jar1.jar:jar2.jar myprog
于 2012-02-09T13:34:06.537 回答
0

查看错误,它抱怨无法找到“userapps.SelectionTask_classes.SelectionTask”,这暗示您的类路径中的最后一个条目未正确指定。现在,假设您指定的 JAR 文件位于以下目录结构中:

./hadoop-0.20.1-core.jar

./lib/hadoopdb.jar

./userapps/SelectionTask_classes/

你会运行:

java -cp hadoop-0.20.1-core.jar:lib/hadoopdb.jar:userapps/SelectionTask_classes/ myprog
于 2012-02-09T14:11:41.577 回答