java - openmpi + java,无法找到或加载主类

标签 java mpi noclassdeffounderror openmpi

我最近正在尝试 openmpi 库的 java 绑定(bind):

我已经使用以下配置成功编译了库:

$/configure --prefix "/home/yuechuan/Application/.openmpi" --enable-mpi-java --with-jdk-dir="/usr/lib/jvm/java-8-oracle/" --with-jdk-header="/usr/lib/jvm/java-8-oracle/include/"

$sudo make install

我可以使用以下命令编译一个简单的java程序:$mpijavac src/com/cyc115/pa2/Main.java

当前$echo $CLASSPATH给出/home/yuechuan/Github/parallel_pa2/src/com/cyc115/pa2/

但是我无法运行类文件。以下是我迄今为止尝试过的一些替代方案:

$java -Djava.library.path=/home/yuechuan/Application/.openmpi/lib/mpi.jar -cp .:/home/yuechuan/Application/.openmpi/lib/mpi.jar Main

返回错误:无法找到或加载主类Main错误。

纯粹而简单的$java Main命令返回NoClassDefFoundError

Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.NoClassDefFoundError: mpi/MPIException
    at java.lang.Class.getDeclaredMethods0(Native Method)
    at java.lang.Class.privateGetDeclaredMethods(Class.java:2701)
    at java.lang.Class.privateGetMethodRecursive(Class.java:3048)
    at java.lang.Class.getMethod0(Class.java:3018)
    at java.lang.Class.getMethod(Class.java:1784)
    at sun.launcher.LauncherHelper.validateMainClass(LauncherHelper.java:544)
    at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:526)
Caused by: java.lang.ClassNotFoundException: mpi.MPIException
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 7 more

如果有人需要的话,这是 java 文件:

package com.cyc115.pa2;

import mpi.MPI;
import mpi.MPIException;

public class Main {

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

        int rank = MPI.COMM_WORLD.getRank();
        int size = MPI.COMM_WORLD.getSize();

        System.out.print("hello world");
        MPI.Finalize();
    }
}

关于如何让 .class 运行有什么想法吗?

最佳答案

由于包是:

package com.cyc115.pa2;

您需要将文件 Main.java 放在名为 com/cyc115/pa2 的子目录中 java 库路径应该是包含 libmpi_java.so 的目录路径,而不是 mpi.jar 的路径。

编译:

javac -cp /home/yuechuan/Application/.openmpi/lib/mpi.jar com/cyc115/pa2/Main.java 

运行:

java -Djava.library.path=/home/yuechuan/Application/.openmpi/lib/ -cp .:/home/yuechuan/Application/.openmpi/lib/mpi.jar com.cyc115.pa2.Main

以下不是问题,仅供引用:

它应该是带有 s 的 --with-jdk-headers 而不是 --with-jdk-header 但是您根本不必指定它,如果您已经指定了 --with-jdk-dir

关于java - openmpi + java,无法找到或加载主类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33189732/

相关文章:

java - 用于存储按字母顺序排列的单词列表的最有效数据结构

Java锁: Hand over hand locking through list

c++ - 如何在 MPI 中创建新类型

google-app-engine - jTwitter、oAuth 和 Google App Engine。没有发现类定义错误

android - 书法库上的 NoClassDefFoundError

java - 在 Play 中通过多对多关系过滤模型对象! 2.0

java - 在 Java 中创建 Calendar 对象的临时副本

c - MPI - 段错误退出代码 : 139

c++ - MPI 中使用 MPI_Comm_spawn 生成进程的奇怪输出

java - 运行 gradle 测试时出现 NoClassDefFoundError、FxRobotException、FatalBeanException 和 ExecutionException