私は最近、openmpiライブラリのJavaバインディングを試しています:
次の構成でlibを正常にコンパイルしました。
$/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
これはError: Could not find or load main class 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
以下は問題ではなく、参考までに。
を指定している場合は、指定する必要はありませんが--with-jdk-headers
、sを使用する必要があり--with-jdk-header
ます--with-jdk-dir
。
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加