java - 无法用 Java 编译 MPI 程序 - UnsupportedClassVersionError

标签 java mpj-express

我对 MPJ 完全陌生,MPJ 是一种用于在 Java 中开发基于 MPI 的程序的 API。我写了一个简单的代码如下:

import mpi.MPI;
import mpi.Status;

public class Send {
    public static void main(String[] args) throws Exception
    {
        MPI.Init(args);

        int rank = MPI.COMM_WORLD.Rank();
        int size = MPI.COMM_WORLD.Size();
        int peer;

        int buffer[] = new int[10];
        int len = 1;
        int dataToBeSent = 99;
        int tag = 100;

        if(rank == 0)
        {
            buffer[0] = dataToBeSent;
            peer = 1;
            MPI.COMM_WORLD.Send(buffer, 0, len, MPI.INT, peer, tag);
            System.out.println("process <"+rank+"> sent a msg to process <"+peer+">");             
        }
        else if(rank == 1)
        {
             peer = 0 ; 
             Status status = MPI.COMM_WORLD.Recv(buffer, 0, buffer.length, MPI.INT, peer, tag);
             System.out.println("process <"+rank+"> recv'ed a msg\n"+ "\tdata <"+buffer[0]+"> \n"+"\tsource <"+status.source+"> \n"+"\ttag<"+status.tag+"> \n"+"\tcount  <"+status.count +">");             
        }
        MPI.Finalize();
    }
}

编译时出现如下错误:

Exception in thread "main" java.lang.UnsupportedClassVersionError: mpi/MPI : Unsupported major.minor version 51.0
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:620)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:124)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:260)
    at java.net.URLClassLoader.access$000(URLClassLoader.java:56)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:195)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:276)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:251)
    at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:319)
    at Send.main(Send.java:7)
Java Result: 1

为了解决这个问题,我了解到我的 JDK 和 JRE 版本必须相同。执行以下命令后,我发现它们是一样的,没有什么不同:

C:\Users\Dev>javac -version
javac 1.6.0

C:\Users\Dev>java -version
java version "1.6.0"
Java(TM) SE Runtime Environment (build 1.6.0-b105)
Java HotSpot(TM) Client VM (build 1.6.0-b105, mixed mode, sharing)

在 Ubuntu Java 8 中,我得到以下异常:

Exception in thread "main" mpi.MPIException: Usage: java MPI <myrank> <conf_file> <device_name> conf_file can be, ../conf/xdev.conf <Local>OR http://holly.dsg.port.ac.uk:15000/xdev.conf <Remote>
    at mpi.MPI.Init(MPI.java:233)
    at mpi.MPI.Init(MPI.java:233)   at mpi.MPI.Init(MPI.java:233)
    at Send.main(Send.java:7)
Java Result: 1

如何解决此问题并让 MPI 在我的系统上运行 Java?

最佳答案

这是一个老问题,但我想我可以总结一下这里发生的事情,因为我自己使用过这个库。

您获得的编译错误“Unsupported major.minor version 51.0”表示您用于运行程序的 java 版本太旧。您的程序的某些部分很可能是使用较新版本的 Java 编译的。可能是您下载的 MPJ 库?

当您尝试使用 Java 8 运行您的程序时,您实际上已经自己解决了这个问题!但是,正如您在问题的后半部分正确识别的那样,您的程序参数仍然存在问题。 MPJ-express main 需要一些特定的参数来知道有多少进程正在启动。如果没有这些参数,您会收到错误 Exception in thread "main" mpi.MPIException: Usage: java MPI <myrank> <conf_file> <device_name>

基本上,MPJ-Express 库附带了一些小脚本,可以为您安排 MPI 特定参数。根据您要使用的模式(多核/集群),脚本和过程会有所不同。本页提供的指南中解释了所有详细信息:http://mpj-express.org/guides.html .如果这是您正在使用的,您还可以从 Eclipse IDE 中启动程序。

关于java - 无法用 Java 编译 MPI 程序 - UnsupportedClassVersionError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29418322/

相关文章:

java - 通过自定义类在javafx中添加事件处理程序

java - "Unresolved compilation problems"来自在 Eclipse Indigo 中运行 MPJ express

java - 调用 MPI.Init(args) 时出现异常

java - 如何从 hibernate 中的类型化查询返回不是实体的对象列表?

java - 有没有办法按升序和降序对 Mpi 中的排名进行排序

java - 为什么使用MPJ Express的程序会出现异常?

java - 使用 mpj-express 读取控制台输入

java - 如何使用 Java 在 Selenium WebDriver 中按 "ALT+S"

java - MySQL 将或不会返回重复行,具体取决于特定列是否存在。为什么?

java - 在屏幕上打印重复循环