java中jna调用c_JNA传引用调用C接口

新建一个简单的cmake管理的c++工程,只包含一个MakeLists.txt和src1.cpp,内容分别如下

cmake_minimum_required(VERSION 3.0)

project(jna_test C CXX)

add_library(foo SHARED src1.cpp)

/*

* src1.cpp

*

* Created on: Jan 28, 2019

* Author: link

*/

#include

#include

#include

#include

using namespace std;

class T {

public:

void print() { cout << "T print" << endl;}

};

#ifdef __cplusplus

extern "C" {

#endif

void foo(char ** output, char * len) {

T t;

t.print();

*len = 10;

*output = (char *) calloc(1, *len);

memcpy(*output, "1234567890", *len);

}

#ifdef __cplusplus

}

#endif

因为JNA只支持C风格动态库接口,而工程是c++风格,必须使用__cplusplus宏和extern "C"把foo函数以C风格输出。foo函数内调用类T.print函数,给*output指针分配10个字节,并复制字符串。

在Java端的测试工程中加入jna依赖坐标

net.java.dev.jna

jna

5.2.0

DirectMap方式调用foo函数

import com.sun.jna.*;

import com.sun.jna.ptr.*;

public class DirectJNA {

static {

//foo是库的名称,且能在系统环境变量LD_LIBRARY_PATH或者JVM参数jna.library.path中能搜索到libfoo.so

Native.register("foo");

}

//映射libfoo.so中的函数foo(char **output, int * len)

public static native void foo(PointerByReference bufp, IntByReference lenp);

public static void main(String[] args) {

PointerByReference bufp = new PointerByReference();

IntByReference lenp = new IntByReference();

foo(bufp, lenp);

Pointer p = bufp.getValue();

byte[] buffer = p.getByteArray(0, lenp.getValue());

System.out.println(new String(buffer));

}

}

由于是在c库的foo函数分配内存,为了传递给JNA调用,foo函数中并没有释放此内存,JNA对于什么时候释放并没有做交代。

参考

https://github.com/java-native-access/jna/blob/master/www/ByRefArguments.md

https://github.com/java-native-access/jna/blob/master/www/DirectMapping.md

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值