【发布时间】:2015-11-23 18:58:11
【问题描述】:
调用 JNI 方法时出现 Unsatisfied link 错误。以下是我的日志
日志
new exception [Handler processing failed; nested exception is java.lang.UnsatisfiedLinkError: demo.JNIWrapper.packet_mining_start(Ljava/lang/String;)I] with root cause
java.lang.UnsatisfiedLinkError: demo.JNIWrapper.packet_mining_start(Ljava/lang/String;)I
at demo.JNIWrapper.packet_mining_start(Native Method)
at demo.RESTController.getPcap(RESTController.java:97)
下面是我的 JNI 代码
public class JNIWrapper {
static{
System.load("/home/XXX/XXX/Library/newJNI/libJNIDemo.so");
}
//Get Path in output param and status
public native int packet_mining_start(String fileName);
}
现在从文件 Main.java 调用此方法,并在为此类创建对象时 (JNIWrapper jni=new JNIWrapper()),在此期间调用 System.load 我没有收到任何错误。
现在当我在 JNI 中调用方法 packet_mining_start 时出现错误。
我的.h文件方法是(注意不是从Java类文件创建的)
uint32_t pax_packet_mining_start(uint8_t* mining_query_file_name);
此方法中不包含 JNIExport 和 JNICall 变量或类型。因此,如果不包含 JNIExport 的方法并调用该方法会给出 UnsatisfiedLink 错误?
本地方法中是否必须有 JNICall 和 JNIExport ?
如何将它与我的普通 c 文件集成?
【问题讨论】:
-
My .h file method is (Note not created from the Java class file )所以你没有使用javah.exe创建 C 头文件? -
@PaulMcKenzie 是的,我没有使用 javah 创建头文件(基本上是在试验如何在不使用 javah 创建头文件的情况下调用本机方法)
-
堆栈跟踪
demo.JNIWrapper.packet_mining_start(Ljava/lang/String;)I描述的方法与您提供的Java 代码中声明的方法不匹配。它们的参数数量和类型不同。要么您遗漏了关键细节,要么您的课程处于不一致的状态。 -
@JohnBollinger 在本机方法中是否必须有 JNICall 和 JNIExport ?因为我怀疑 JNI 方法不包含 JNIExport 和 JNICall 它可能是问题,我的 JNI 方法是 uint32_t pax_packet_mining_start(uint8_t*挖掘查询文件名);
-
另外,您通常会给
System.loadLibrary()一个不带“.so”扩展名或路径的库名称。代替路径,您可以设置LD_LIBRARY_PATH以包含可以找到库的目录(在启动程序之前)。然而,也许 Java 足够聪明,可以理解您给出的形式。
标签: java c++ c java-native-interface