我想在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
我不知道为什么,但这可以防止错误。