转-Exception in thread “main” java.lang.NoClassDefFoundError错误解决


http://www.codezyw.com/2015/03/15/转-java开发和运行环境的搭建/

http://blog.csdn.net/xw13106209/article/details/6861855

1参考文献

文献1:http://topic.csdn.net/u/20070812/16/b24350b6-3db4-4f7e-9861-1a113f53adff.html

文献2:http://doc.linuxpk.com/4703.html

2错误描述

javac helloworld.java能够通过。但是java helloworld出现错误:

  1. hadoop@xuwei-erplab:~/jarfile$ java HelloWorld
  2. Exception in thread “main” java.lang.NoClassDefFoundError: HelloWorld (wrong name: org/xuwei/HelloWorld)
  3.     at java.lang.ClassLoader.defineClass1(Native Method)
  4.     at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
  5.     at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
  6.     at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
  7.     at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
  8.     at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
  9.     at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
  10.     at java.security.AccessController.doPrivileged(Native Method)
  11.     at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
  12.     at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
  13.     at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
  14.     at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
  15. Could not find the main class: HelloWorld.  Program will exit.

3问题解决

在文献1中很多人提到都是因为环境变量classpath配置错误。说是没有加上当前路径”.”。但是我查看了自己的classpath为

  1. export CLASSPATH=.:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:$CLASSPATH

这表明我的classpath配置是正确的。这个时候我找到了文献2,里面提到了helloword分为带包名和不带包名两类。

4不含包层次的HelloWorld.java

  1. public class HelloWorld {
  2.     public static void main(String args[]){
  3.         System.out.println(“Hello World!”);
  4.     }
  5. }

保存在/home/hadoop/jarfile下,使用javac命令编译:

  1. $ javac HelloWorld.java

运行:

  1. $ java HelloWorld

屏幕打印出:
  Hello World!

5初学者常犯的错误

5.1. 运行时,带了.class后缀

如果你试图使用如下命令:(下面的命令都是假设在HelloWorld.java所在目录执行,即/home/hadoop/jarfile)

  1. java HelloWorld.class

系统会误认为你运行的是HelloWorld包下的名为class的类文件,会到系统的CLASSPATH下(一般都包括当前目录)企图寻找 HelloWorld.class.class这样的类,这样的类当然不存在了;并且也不可能存在,因为class是关键字,不能作为一个类的名字。所以会报如下错误信息:
Exception in thread “main” java.lang.NoClassDefFoundError: HelloWorld/class

5.2. 文件名大小写错误

对于像Windows这样的系统,编译时可以不关心大小写(linux区分大小写)。比如编译HelloWorld.java时,也可以使用:

  1. javac helloworld.java

也可以编译通过,但产生的类文件仍然是和源文件相符的:HelloWorld.class。但在运行时一定要注意大小写,比如试图使用如下命令运行:

  1. java helloworld

将报类似于1中的错误:
Exception in thread “main” java.lang.NoClassDefFoundError: helloworld (wrong name: HelloWorld)

6包含包层次的HelloWorld.java

比如上面的HelloWorld.java修改如下:

  1. package org.myorg;
  2. public class HelloWorld {
  3.     public static void main(String args[]){
  4.         System.out.println(“Hello World!”);
  5.     }
  6. }

编译时有两种方法

6.1. 直接编译

  1. javac HelloWorld.java

此时在当前目录下输出HelloWorld.class。此时,运行不能使用上面相同的方法,使用:

  1. java HelloWorld

运行时,出现如下错误:
Exception in thread “main” java.lang.NoClassDefFoundError: HelloWorld (wrong name: org/myorg/HelloWorld)
从上述错误信息你也可以看到,系统可以找到HelloWorld类(因为当前路径包含在CLASSPATH中,具体为什么会提示wrong name,有兴趣的朋友参见Java语言规范),但这个类属于org.myogr包。所以,你要做的就是按照上述包层次,相应的创建目录层次,把上面生成的HelloWorld.class放到/home/hadoop/jarfile/org/myorg目录下。HelloWorld.java在/home/hadoop/jarfile/目录下。运行:

  1. java org.myorg.HelloWorld

系统打印出:
 Hello World! 

这儿要注意的是,不能使用java org\myorg\HelloWorld来运行,此时同样会出现如下错误:

Exception in thread “main” java.lang.NoClassDefFoundError :org\myorg\HelloWorld (wrong name: org\myorg\HelloWorld)
是不是有点怪怪的,那没办法。以后对Java的包有更深的认识时,就会明白了。

6.2. 使用 -d <directory>编译选项

是不是觉得上面的编译方法有点麻烦,能不能自动在当前路径(或任意指定的路径)下生成包层次呢?有!使用-d <directory>编译选项就能做到。

  1. javac -d . HelloWorld.java

此时,在当前目录(/home/hadoop/jarfile)下就生成了一个org\myorg目录(/home/hadoop/jarfile/org/myorg),并且输出的.class文件也在里面。运行:

  1. java org.myorg.HelloWorld

系统打印:

Hello World!

如果你想把生成的类文件集中存放在一个目录中,比如:/home/hadoop/jarfile/test下,那么你首先创建这个目录,然后编译时:

  1. javac -d /home/hadoop/jarfile/test HelloWorld.java

就可以把生成的类文件放到/home/hadoop/jarfile/test目录下,并且按照包层次相应的创建目录路径。你可以在/home/hadoop/jarfile/test/org/myorg下找到HelloWorld.class文件。此时使用如下命令可以正确运行(注意如果要用到其它类,请在CLASSPATH中设好):

  1. hadoop@xuwei-erplab:~/jarfile/test$ java org.xuwei2.HelloWorld

注意上述命令是在/home/hadoop/jarfile/test下执行的。