关与java与javac版本不一致问题

  • 出现的问题
  • 解决方法
  • 总结


出现的问题

用java执行test.class字节文件时出现以下错误

java javac版本不一致 java与javac版本不一致_java javac版本不一致

Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.UnsupportedClassVersionError: test has been compiled by a more recent version of the Java Runtime (class file version 55.0), this version of the Java Runtime only recognizes class file versions up to 52.0
        at java.lang.ClassLoader.defineClass1(Native Method)
        at java.lang.ClassLoader.defineClass(Unknown Source)
        at java.security.SecureClassLoader.defineClass(Unknown Source)
        at java.net.URLClassLoader.defineClass(Unknown Source)
        at java.net.URLClassLoader.access$100(Unknown Source)
        at java.net.URLClassLoader$1.run(Unknown Source)
        at java.net.URLClassLoader$1.run(Unknown Source)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(Unknown Source)
        at java.lang.ClassLoader.loadClass(Unknown Source)
        at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
        at java.lang.ClassLoader.loadClass(Unknown Source)
        at sun.launcher.LauncherHelper.checkAndLoadMain(Unknown Source)

一开始我以为是因为%JAVA_HOME%/bin路径下的java.exe与javac.exe的版本不同的问题,然后分别查询双方版本信息,如下

java javac版本不一致 java与javac版本不一致_Source_02


当我在其他路径下查询java与javac版本时,会发现两者版本不一

java javac版本不一致 java与javac版本不一致_javac_03


那么此时问题就出在环境变量上面了。

首先说说环境变量中的Path

java javac版本不一致 java与javac版本不一致_javac_04


在Windows命令行下执行命令时,先从当前目录搜素,然后按照Path设置的路径依次查找命令,比如我在桌面上的用javac.exe编译test.java时,会先从桌面下查询有无javac.exe这个可执行程序的存在,若无,则从Path中从上到下从左到右逐个选出一条路径进行搜索javac.exe

java javac版本不一致 java与javac版本不一致_java javac版本不一致_05


问题就出在这里

我寻找到C:\Program Files (x86)\Common Files\Oracle\Java\javapath这个路径,发现存在另外的java.exe

java javac版本不一致 java与javac版本不一致_javac_06


这个时候情况就一目了然,系统在寻找java.exe时是从上到下,从左到右逐个选择一条路径进行查询,而C:\Program Files (x86)\Common Files\Oracle\Java\javapath在%JAVA_HOME%之前

所以javac编译时用的javac是11.0.2版本的

使用java时用的是C:\Program Files (x86)\Common Files\Oracle\Java\javapath下的1.8.0_181版的java.exe

可以验证一下,进入C:\Program Files (x86)\Common Files\Oracle\Java\javapath路径,检查其下java.exe的版本

java javac版本不一致 java与javac版本不一致_java javac版本不一致_07

解决方法

将Path中%JAVA_HOME%/bin这条路径放在C:\Program Files (x86)\Common Files\Oracle\Java\javapath路径之前即可解决问题

java javac版本不一致 java与javac版本不一致_Java_08


java javac版本不一致 java与javac版本不一致_java javac版本不一致_09

总结

遇见问题得多思考,其实答案可能就在那不起眼的地方。window下的设置还是考虑的挺周到的,只是因为我们知识不足才没有发现到,比如编辑环境变量下的上移下移功能,就可以知道Path提取路径是有先后顺序的。