我有一个以前用于c#应用程序的c ++ dll。现在我们想对java使用相同的dll。我知道我们可以使用JNI技术,但问题是我们必须使用相同的方法签名,我们不想改变方法singnature。请告诉我。
答案 0 :(得分:1)
一种选择是使用JNA而不是JNI。它消除了对样板本机代码的需要。一个例子看起来像这样......
import com.sun.jna.Library;
import com.sun.jna.Native;
public class Example {
public interface NativeMath extends Library {
public bool isPrime(int x);
}
public static void main(String[] args) {
int x = 83;
NativeMath nm = (NativeMath) Native.loadLibrary("nm", NativeMath.class);
System.out.println(x + " is prime: " + nm.isPrime(x));
}
}
答案 1 :(得分:-1)
您不必更改方法签名,只需添加一个本机方法,然后调用本机C ++代码。这是一个简单的例子:
public class Someclass
{
public native void thisCallsCMethod(Someparams);
}
现在创建JNI包装器:
javac Someclass.java
javah Someclass
这将创建一个Someclass.h,然后创建Someclass.cpp并在其中包含.h。 此时,您所要做的就是编写thiCallsCMethod的C / C ++代码
在.h中,您将看到必须实施的方法签名。有点像:
#include "clibraryHeader.h"
using namespace clibraryNamespace;
JNIEXPORT void JNICALL thisCallsCMethod(JNIEnv *, someparameters)
{
cout<<"Yeah C code is being called"<<endl;
someCfunction();
}
显然你必须按摩JNI调用中的参数,但是你可以创建一些临时变量,然后将你从C调用中获得的值复制回传入参数(如果需要返回)等等。
也许:
#include "clibraryHeader.h"
using namespace clibraryNamespace;
JNIEXPORT void JNICALL thisCallsCMethod(JNIEnv *, someparameters)
{
cout<<"Yeah C code is being called"<<endl;
Cstruct temp;
temp1.somevar = param1.getSomeVal()
someCfunction(temp);
}