我完全了解Java,但我已经解决了这个问题。我正在使用JNA并拥有一个文件:
public interface JRockey4ND extends Library {
public short rockey(short func, short[] handle, int[] lp1, int[] lp2, short[] p1, short[] p2, short[] p3, short[] p4, byte[] buffer);
public short RY_FIND=1;
public short RY_FIND_NEXT=2;
}
并在另一个档案中:
JRockey4ND rockey = (JRockey4ND) Native.loadLibrary(libFileName, JRockey4ND.class);
.
.
retval=rockey.rockey(rockey.RY_FIND,handle[0],lp1,lp2,p1,p2,p3,p4,buffer);
它就像一个魅力。但是根据平台,我必须使用Rockey
方法而不是rockey
,因为导出的符号在Linux .so和Windows .dll之间命名不匹配。我尝试使用perl -pi -e 's/rockey/Rockey/g' lib.so
替换so文件中的符号名称,但它不起作用(符号' Rockey'之后无法找到,尽管替换)。
所以我的问题是,如何以最简单的方式(不是最漂亮的方式)以编程方式解决这个问题。非常感谢!
答案 0 :(得分:2)
根据JNA JavaDoc,您可以在初始化库时提供FunctionMapper
选项,将方法名称映射到库名称。
FunctionMapper mapper = new FunctionMapper() {
public String getFunctionName(NativeLibrary library, Method method) {
if (Platform.isWindows()) {
if (method.getName().equals("rocket")) {
return "Rocket";
}
}
return method.getName();
} }; Map options = new HashMap(); options.put(Library.OPTION_FUNCTION_MAPPER,mapper); Native.loadLibrary(" rocket",Rocket.class,options);