我想在Java中运行的Apache Spark中使用现有的C ++代码。我使用SWIG来生成JNI接口,只要我从这样的简单类(MyJavaClass.java)调用函数,它就可以像超级按钮一样工作:

public class MyJavaClass {
  public static void main(String[] args) {
    System.loadLibrary("mycppcode");
    mycppcode.dostuff();
  }
}


然后,我尝试将类集成到我的打包层次结构中,我需要能够从Spark(MyJavaClass.java)调用它:

package com.mycompany.mypackage;

public class MyJavaClass {
  public void MyJavaMethod() {
    System.loadLibrary("mycppcode");
    mycppcode.dostuff();
  }
}


但是,一旦添加打包行,在文件上运行javac时就会出现以下错误:

MyJavaClass.java:6: error: cannot find symbol
        mycppcode.dostuff();
        ^
  symbol:   variable mycppcode
  location: class MyJavaClass
1 error


我使用以下命令来生成JNI,libmycppcode.so库和Java类:

swig -c++ -java -package com.mycompany.mypackage mycppcode.i
g++ -fpic -c mycppcode.cpp mycppcode_wrap.cxx -std=c++17 -I/usr/lib/jvm/java-8-openjdk-amd64/include -I/usr/lib/jvm/java-8-openjdk-amd64/include/linux
g++ -shared mycppcode.o mycppcode.o -o libmycppcode.so
javac MyJavaClass.java


这是C ++文件(mycppcode.cpp):

#include <iostream>
using namespace std;

int dostuff() {
    cout << "Hello World!" << endl;
}


这是接口文件(mycppcode.i):

%module mycppcode
%{
extern int dostuff();
%}
extern int dostuff();


这是生成的JNI文件(mycppcodeJNI.java):

package com.mycompany.mypackage

public class mycppcodeJNI {
  public final static native int dostuff();
}


这是生成的Java文件(mycppcode.java):

public class mycppcode {
  public static int dostuff() {
    return mycppcodeJNI.dostuff();
  }
}

最佳答案

我刚开始工作。非常感谢@Michael提供-package参数的提示。

问题似乎是我试图从类文件的实际文件夹中运行javac,如下所示:

~/myproject/src/com/mycompany/mypackage$ javac MyJavaClass.java


相反,需要从根源目录执行javac,如下所示:

~/myproject/src$ javac com/mycompany/mypackage/MyJavaClass.java


我不知道为什么,但这可以防止错误。

10-06 07:11