Error: A JNI error has occurred, please check your installation and try again - during running Java program from Ubuntu terminal
Error: A JNI error has occurred, please check your installation and try again - during running Java program from Ubuntu terminal
我正在尝试通过 Ubuntu 终端 运行 用 Java 编写的简单客户端-服务器程序。不幸的是,我可以成功编译代码,但我不能 运行 代码。
服务器class代码:
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
public class Server
{
public static void main(String[] args)
{
try
{
//create server Socket with demo port
ServerSocket server = new ServerSocket(20);
//wait for server connection
Socket s = server.accept();
//upon establishing connection, print
// successful message
System.out.println("connection eastablished");
}
catch (IOException e)
{
e.printStackTrace();
}
}
}
客户class代码:
import java.io.IOException;
import java.net.Socket;
import java.net.UnknownHostException;
public class Client
{
public static void main(String[] args)
{
try
{
//create client socket
Socket client = new Socket("127.0.0.1", 20);
//upon establishing connection, print
//successful message
System.out.println("connection eastablished");
}
catch (UnknownHostException e)
{
e.printStackTrace();
}
catch (IOException e)
{
e.printStackTrace();
}
}
}
在 运行 编译 class 期间,我收到以下错误:
mamun@mamun:~$ java Test 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(ClassLoader.java:763) at
java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:467) at
java.net.URLClassLoader.access0(URLClassLoader.java:73) at
java.net.URLClassLoader.run(URLClassLoader.java:368) at
java.net.URLClassLoader.run(URLClassLoader.java:362) at
java.security.AccessController.doPrivileged(Native Method) at
java.net.URLClassLoader.findClass(URLClassLoader.java:361) at
java.lang.ClassLoader.loadClass(ClassLoader.java:424) at
sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349) at
java.lang.ClassLoader.loadClass(ClassLoader.java:357) at
sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:495)
我尝试搜索 Whosebug 和其他论坛和博客以找到解决方案,我发现了一些类似的问题,尝试了为这些问题提供的答案,但可以找到解决我的问题的方法。这就是为什么我在这里添加这个问题。
后来,我试着写了一个非常简单的Java程序,比如只打印一句问候语,这个程序也可以编译但不会运行产生同样的错误。
我尝试从根文件夹以外的不同文件夹执行程序。但是所有的努力都会产生相同的结果。
public class Test
{
public static void main(String[] args)
{
System.out.println("Hello...");
}
}
我可以在我的 java 版本 8 中完美地工作,只有在终端中工作时才会出现问题。
我的Ubuntujdk版本是11(在我不知情的情况下已经自动更新);
我的 Ubuntu version:18.04.1 LTS
错误说明了一切:
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)...
您已为 Java 11 编译...但您是 运行 较旧的 JRE (Java 8)。
建议:
使用 -source
和 -target
重新编译以在您的 .class 文件中以 Java 的早期版本为目标,或者
将您的目标 JRE 升级到 Java11
示例:javac -target 8 -source 8 MyClass.java
仅供参考,这些是每个 Java class 文件中的 Java 版本 header:
https://en.wikipedia.org/wiki/Java_class_file
- Java SE 11 = 55 (0x37 hex)
- Java SE 10 = 54 (0x36 hex)
- Java SE 9 = 53 (0x35 hex)
- Java SE 8 = 52 (0x34 hex)
- Java SE 7 = 51 (0x33 hex)
- Java SE 6.0 = 50 (0x32 hex)
- Java SE 5.0 = 49 (0x31 hex)
- JDK 1.4 = 48 (0x30 hex)
- JDK 1.3 = 47 (0x2F hex)
- JDK 1.2 = 46 (0x2E hex)
- JDK 1.1 = 45 (0x2D hex)
另外仅供参考,这里是 javac 的命令行选项:
PS:
您可以同时安装 Java 的多个独立版本。使用alternatives命令:
我也遇到了这个问题。这是我的解决方案。
安装了 2 个 Java 版本(java 8 和 Java SE 开发工具包 13)。
由于这 2 个版本而发生此错误。只需卸载旧版本即可。
(*Java 使用 SE 开发工具包编译 .java 文件并尝试使用旧版本执行。因此发生兼容错误。)
然后使用 javac -version
和 java -version
在 cmd 上检查 java 版本。卸载后两个版本号必须相同
我正在尝试通过 Ubuntu 终端 运行 用 Java 编写的简单客户端-服务器程序。不幸的是,我可以成功编译代码,但我不能 运行 代码。
服务器class代码:
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
public class Server
{
public static void main(String[] args)
{
try
{
//create server Socket with demo port
ServerSocket server = new ServerSocket(20);
//wait for server connection
Socket s = server.accept();
//upon establishing connection, print
// successful message
System.out.println("connection eastablished");
}
catch (IOException e)
{
e.printStackTrace();
}
}
}
客户class代码:
import java.io.IOException;
import java.net.Socket;
import java.net.UnknownHostException;
public class Client
{
public static void main(String[] args)
{
try
{
//create client socket
Socket client = new Socket("127.0.0.1", 20);
//upon establishing connection, print
//successful message
System.out.println("connection eastablished");
}
catch (UnknownHostException e)
{
e.printStackTrace();
}
catch (IOException e)
{
e.printStackTrace();
}
}
}
在 运行 编译 class 期间,我收到以下错误:
mamun@mamun:~$ java Test 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(ClassLoader.java:763) at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) at java.net.URLClassLoader.defineClass(URLClassLoader.java:467) at java.net.URLClassLoader.access0(URLClassLoader.java:73) at java.net.URLClassLoader.run(URLClassLoader.java:368) at java.net.URLClassLoader.run(URLClassLoader.java:362) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(URLClassLoader.java:361) at java.lang.ClassLoader.loadClass(ClassLoader.java:424) at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349) at java.lang.ClassLoader.loadClass(ClassLoader.java:357) at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:495)
我尝试搜索 Whosebug 和其他论坛和博客以找到解决方案,我发现了一些类似的问题,尝试了为这些问题提供的答案,但可以找到解决我的问题的方法。这就是为什么我在这里添加这个问题。
后来,我试着写了一个非常简单的Java程序,比如只打印一句问候语,这个程序也可以编译但不会运行产生同样的错误。 我尝试从根文件夹以外的不同文件夹执行程序。但是所有的努力都会产生相同的结果。
public class Test
{
public static void main(String[] args)
{
System.out.println("Hello...");
}
}
我可以在我的 java 版本 8 中完美地工作,只有在终端中工作时才会出现问题。
我的Ubuntujdk版本是11(在我不知情的情况下已经自动更新); 我的 Ubuntu version:18.04.1 LTS
错误说明了一切:
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)...
您已为 Java 11 编译...但您是 运行 较旧的 JRE (Java 8)。
建议:
使用
-source
和-target
重新编译以在您的 .class 文件中以 Java 的早期版本为目标,或者将您的目标 JRE 升级到 Java11
示例:javac -target 8 -source 8 MyClass.java
仅供参考,这些是每个 Java class 文件中的 Java 版本 header:
https://en.wikipedia.org/wiki/Java_class_file
- Java SE 11 = 55 (0x37 hex)
- Java SE 10 = 54 (0x36 hex)
- Java SE 9 = 53 (0x35 hex)
- Java SE 8 = 52 (0x34 hex)
- Java SE 7 = 51 (0x33 hex)
- Java SE 6.0 = 50 (0x32 hex)
- Java SE 5.0 = 49 (0x31 hex)
- JDK 1.4 = 48 (0x30 hex)
- JDK 1.3 = 47 (0x2F hex)
- JDK 1.2 = 46 (0x2E hex)
- JDK 1.1 = 45 (0x2D hex)
另外仅供参考,这里是 javac 的命令行选项:
PS:
您可以同时安装 Java 的多个独立版本。使用alternatives命令:
我也遇到了这个问题。这是我的解决方案。 安装了 2 个 Java 版本(java 8 和 Java SE 开发工具包 13)。 由于这 2 个版本而发生此错误。只需卸载旧版本即可。 (*Java 使用 SE 开发工具包编译 .java 文件并尝试使用旧版本执行。因此发生兼容错误。)
然后使用 javac -version
和 java -version
在 cmd 上检查 java 版本。卸载后两个版本号必须相同