SWIG:如何处理生成的Java代码中的指针

时间:2017-07-17 09:18:14

标签: java c++ swig

我使用SWIG为我的一个C lib生成Java绑定。但是我在处理C指针方面遇到了麻烦。这里有一些代码来展示我的问题:

calc.h文件:

extern int sum(int a, int b);
extern int sum_1(int *a, int *b);

calc.c文件:

#include "calc.h"

int sum(int a, int b) {
  return a + b;
}

int sum_1(int *a, int *b) {
  return *a + *b;
}

calc.i文件:

%module calc
%{
#include "calc.h"
%}

%include "calc.h"

我使用以下命令生成Java绑定代码:

gcc -c calc.c
swig -java calc.i
gcc -fpic -c calc_wrap.c -I/usr/lib/jvm/java-1.8.0/include -I/usr/lib/jvm/java-1.8.0/include/linux
ld -G calc_wrap.o calc.o -o libcalc.so

现在我的主要功能:

public class Application {
  static {
    System.loadLibrary("calc");
  }

  public static void main(String[] args) {
    System.out.println(calc.sum(1, 2));
    // System.out.println(calc.sum_1(?, ?));
  }
}

以上代码将编译和正常运行并按预期打印3。问题是,如何使用calc.sum_1 func?我完全不知道如何处理int *类型。

仅供参考,附上SWIG生成的一些代码:

calc.java文件:

public class calc {
  public static int sum(int a, int b) {
    return calcJNI.sum(a, b);
  }

  public static int sum_1(SWIGTYPE_p_int a, SWIGTYPE_p_int b) {
    return calcJNI.sum_1(SWIGTYPE_p_int.getCPtr(a), SWIGTYPE_p_int.getCPtr(b));
  }

}

calcJNI.java文件:

public class calcJNI {
  public final static native int sum(int jarg1, int jarg2);
  public final static native int sum_1(long jarg1, long jarg2);
}

SWIGTYPE_p_int.java文件:

public class SWIGTYPE_p_int {
  private transient long swigCPtr;

  protected SWIGTYPE_p_int(long cPtr, @SuppressWarnings("unused") boolean futureUse) {
    swigCPtr = cPtr;
  }

  protected SWIGTYPE_p_int() {
    swigCPtr = 0;
  }

  protected static long getCPtr(SWIGTYPE_p_int obj) {
    return (obj == null) ? 0 : obj.swigCPtr;
  }
}

真的很感谢你的帮助!

1 个答案:

答案 0 :(得分:3)

默认情况下,Swig没有生成创建指针的方法,但这里描述了几种方法:http://web.mit.edu/svn/src/swig-1.3.25/Examples/java/pointer/index.html

例如,将其添加到界面文件的底部:

%include cpointer.i
%pointer_functions(int, intp);

通过以下方式生成一组实用程序函数来创建SWIGTYPE_p_int

SWIGTYPE_p_int p1 = calc.new_intp();
SWIGTYPE_p_int p2 = calc.new_intp();
calc.intp_assign(p1, 1);
calc.intp_assign(p2, 2);

System.out.println(calc.sum_1(p1, p2));

calc.delete_intp(p1);
calc.delete_intp(p2);