最近安装了JDK15,安装完以后跟着网上随便找的教程,像以前一样安装旧版本jdk一样,设置了Path和CLASSPATH两个换将变量,用了一周没出事,今天竟然双双事发,搞清楚了一点东西,特意开文记录。
Path变量
大家都知道这个系统环境变量是路径,命令行运行命令或者程序时会在当前目录和Path中的路径中查找命令或者可执行程序,如果不在,就会报错如下:
C:\Users\Administrator>huhu
'huhu' 不是内部或外部命令,也不是可运行的程序
或批处理文件。
当时设置Path变量时的记录如下:
设置JAVA_HOME变量是正确的。但是注意这个变量只是一个标识符,可以把Path中路径简写一下而已,并非必须。
但是我当时愚笨,竟然设置成了这样:
。。。在命令行敲java -version
回应正确,就以为自己设置对了。实则根本没设置正确。错的非常粗暴——没把俩路径拆分开,即应该写成下面这样。。。
终于是把错误改对了。
那我是怎么发现自己犯错的呢??
因为我想用javadoc生成文档注释,结果一直被提示javadoc不是内部命令也不是外部命令,我就纳闷了,java和javac命令一直用的十分顺手,他们三个exe文件都在同一个已经被我加入Path变量的路径下的呀(如上,其实没正确加入)。
于是一搜索,发现:
原来现在安装jdk之后,java会自动添加一个Path变量:C:\Program Files\Common Files\Oracle\Java\javapath
所以这个路径下的exe文件可以运行,如java,javac,但是javadoc不在这里,所以不行。
所以我才发现自己的Path变量设置错了,重新改好后,javadoc便可用了。
CLASSPATH
先说大结论:jdk自从1.5之后,安装后就完全无需设置CLASSPATH这个环境变量了。只需要设置Path变量。
再说CLASSPATH是什么,它是类路径,即.class文件所在的路径,一般有两种路径,一是当前目录,而是JAR文件所在目录。JAR是java archive,java归档,是java的类库统一组织起来发布的机制。总之它里面放的就是类库的众多已经类的经过编译的字节码类文件。
所以以前都需要在安装jdk之后,把CLASSPATH这个变量设置为当前目录(".")以及dt.jar和tools.jar所在路径:
而现在,jdk15已经没有dt.jar和tools.jar了,只有jrt-fs.jar。
我实验发现,不管CLASSPATH设置为啥,就算是空着,,都可以正确编译和运行,,,,也不需要改为%JAVA_HOME%\lib\jrt-fs.jar;
虽然暂时不知道java用什么办法保证类加载器知道去哪里加载类文件的,但是大结论得到了:无需设置CLASSPATH环境变量。
总结
java一直在进步。类加载器,编译器,虚拟机都在不断进步,以前需要人工手动设置的,都被他们代劳了,现在安装jdk之后只需要给Path添加一下jdk安装的bin路径和jre的bin路径就好了。其他的啥也不需要做。