转Java程序命令行下的执行

IED用惯了,基础都快忘记了

javac 先不说了,环境变量里面设置对了基本没什么问题

关键是java这个命令

java -classpath .class的类路径(如果是包的话,需要指定到包上面的路径);引用的类路径 xx.xx.aaa

(如果是javac的话需要 javac xx\xxx\aaa.java,必须用路径的形式)

注意如果源文件的结构是Package的话,classpath指定到.class文件上面,然后 直接执行aaa是不行的(javac的话可以),必须按上面的规则

举个例子

package a.b.c;   
  
public class hello   
  
{   
  
public static void main(String args[])   
  
{       
  
  System.out.println("Hello the world!");   
 
}   
  
} 



此程序可以编译通过,但是执行时,却提示以下错误!

D:\my\xdj>javac hello.java
D:\my\xdj>java hello

Exception in thread "main" java.lang.NoClassDefFoundError: hello (wrong name: a/

b/c/hello)

        at java.lang.ClassLoader.defineClass0(Native Method)

        at java.lang.ClassLoader.defineClass(ClassLoader.java:537)

        at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:12

3)

        at java.net.URLClassLoader.defineClass(URLClassLoader.java:251)

        at java.net.URLClassLoader.Access$100(URLClassLoader.java:55)

        at java.net.URLClassLoader$1.run(URLClassLoader.java:194)

        at java.security.AccessController.doPrivileged(Native Method)

        at java.net.URLClassLoader.findClass(URLClassLoader.java:187)

        at java.lang.ClassLoader.loadClass(ClassLoader.java:289)

        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:274)

        at java.lang.ClassLoader.loadClass(ClassLoader.java:235)

        at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:302)


在xdj目录下建立一个\a\b\c子目录把hello.java放在它下面,用以下命令进行编译和执行时,可正常通过!


D:\my\xdj>javac d:\my\xdj\a\b\c\hello.java


D:\my\xdj>java a.b.c.hello

Hello the world!

D:\my\xdj>

再看下面另外一种情况,先让我们在xdj目录下建立两个文件a.java和b.java文件,其内容如下。

a.java文件内容:

import a.b.c.*; 

public class a 

{ 

   public static void main(String[] args) 

     { 

       b b1=new b(); 

       b1.print(); 

       } 
} 

a.java文件内容:

package a.b.c;

public class b

{

   public void print()

     {

      System.out.println("我是被调用子类的程序输出呀!");

       }

}


直接编译a.java文件时,会提示以下错误!

D:\my\xdj>javac a.java

a.java:1: package a.b.c does not exist

import a.b.c.*;

a.java:6: cannot access b

bad class file: .\b.java

file does not contain class b

Please remove or make sure it appears in the correct subDirectory of the classpa

th.

       b b1=new b();

       ^

2 errors





D:\my\xdj>

接下来,我们把b.java移到xdj\a\b\c\下,并把\xdj目录下的b.java删除掉呀!重新执行编译指令,这次肯定可以编译成功!你可以发现b.java也同时被编译过了,这就是所谓的make编译方式。

D:\my\xdj>javac a.java

D:\my\xdj>

这时因为,当前classpath路径为D:\my\xdj>

-classpath参数,缺省是以当前目录为根基目录的,即不带-classpath参数的情况下。最好明确指定-classpath选项,可设置环境变量CLASSPATH即可,同时设置了-classpath参数和环境变量classpath时,会以-classpath参数为主的。如果在它们所指定的路径或JAR文件中存有package名称和类名称相同的类,会引起混淆的!

java -classpath path1;path2;.... xx.xxxx.javaname 记住

总结一下:


不管你有没有使用import指令,存在目前目录下的类都会被编译器优先采用,只要它不属于任何package。这是因为编译器总是先假设您所输入的类名就是该类的全名(不属于任何package),然后-classpath所指定的路径中搜索属于该类的.java文件或.class文件,在这里可以知道default package的角色非常特殊。

必须明确告诉编译器我们用到哪个package下的类,导入时或在包名称.类名称中进行引用。导入某个包时,一定要进行-classpath路径指定某个包的位置。你如果指定了多个路径话,如果在一个路径下已经找到了该包话,就优先引用该包的类。

当java编译器开始编译某个类的源代码时,首先它会做一件事情,这就是建立“类路径引用表”,它是根据参数-classpath或classpath环境变量来建立的。如果没有指定选项-classpath或环境变量CLASSPATH时,缺省情况下类路径引用表只有一笔记录,即当前的目录(“.”)。环境变量CLASSPATH的内容会被选项-classpath所覆盖,没有累加效果。

   当编译器将类路径引用表建立好之后,接着编译

你可能感兴趣的:(java,C++,c,.net,C#)