运行jar依赖的java类文件

时间:2012-02-09 13:28:05

标签: java class jar cp

java.lang.NoClassDefFoundError

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

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是我在编译成功后生成的类文件。

3 个答案:

答案 0 :(得分:1)

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

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

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

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

答案 1 :(得分:0)

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

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

答案 2 :(得分: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