如何在.dll和.so中使用JNA与相同的回调签名

前端之家收集整理的这篇文章主要介绍了如何在.dll和.so中使用JNA与相同的回调签名前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在研究一个在WindowsLinux上运行的java项目,我正在使用第三方共享库,这两个操作系统可以使用相同的方法签名.但是,dll的调用约定是stdcall,而共享对象是cdecl.

我想避免重复回调代码,两个接口和两个类,每个调用约定一个接口.我想为回调函数编写一个代码.那可能吗?

在linux下访问.so的代码中唯一的变化是接口.回调函数代码本身是相同的.我会感激任何消化.

import com.sun.jna.Callback;
interface IExternLibCallback extends Callback {..}

这是我为dll中的回调编写的代码

//Interface to stdcall (Windows)
package test1;
import com.sun.jna.win32.StdCallLibrary;
interface IExternLibCallback extends StdCallLibrary.StdCallCallback  {

      void callback (JEventDataStructure context_data);
}

//Class that implements the interface
package test1;
class ExternLibCallback implements IExternLibCallback  {

     ... Other class codes go here ....

  @ Override
  public void callback (JEventDataStructure contextData) {

     ... Code of callback function
  }
}

谢谢,

费尔南多

最佳答案
您可以使用StdCallLibrary / StdCallCallback声明它们,但可能无法在所有平台上定义行为.在不支持备用调用约定的平台上忽略该选项(此时除了win32之外的所有内容),但未必在所有平台上进行测试.

这是首选定义,它仅为windows定义stdcall库.

interface MyLibrary extends Library {
   interface MyCallback extends Callback {
       public void invoke();
   }
   void callbackFunction(MyCallback cb);
   MyLibrary INSTANCE = (MyLibrary)Native.loadLibrary("mylib",Platform.isWindows() ? MyWin32Library.class : MyLibrary.class);
}
interface MyWin32Library extends MyLibrary,StdCallLibrary {
   interface MyStdCallCallback extends MyCallback,StdCallCallback {}
   void callbackFunction(MyStdCallCallback cb);
}

如果你只是针对linux和windows,那么单个界面就足够了(不过我建议测试一下):

interface MyLibrary extends StdCallLibrary {
   interface MyCallback extends StdCallCallback {
       public void invoke();
   }
   void callbackFunction(MyCallback cb);
   MyLibrary INSTANCE = (MyLibrary)Native.loadLibrary("mylib",MyLibrary.class);
}

猜你在找的Linux相关文章