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