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

SWIG:how to deal with pointers in generated Java code

本文关键字:Java 代码 指针 何处理 处理 SWIG      更新时间:2023-10-16

我正在使用SWIG为我的一个C库生成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函数?我完全不知道如何处理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;
}
}

非常感谢您的帮助!

默认情况下,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);