JNA 结构体数组传递地址不连续问题

传单个结构体到C没有问题,但是传递结构体的数组到C一直没有找到正确的方法;忘了是从哪个博客看到的了,记录一下

按照java的方法来初始化数组并给数组里的每个对象赋值,在java层这些对象的地址不是连续的;,所以到底层报错

结构体如下:

      public static class IMAGEDATA extends Structure{
        public int width;
        public int height;       
        public int esolution;
    }

  IMAGEDATA image=new IMAGEDATA();
  IMAGEDATA[] images = ( IMAGEDATA[])image.toArray(2);

 赋值

images[0].width=300;

images[0].height=400;

images[0].esolutioin=500;

 

images[1].width=300;

images[2].height=400;

images[1].esolutioin=500;

 

传递结构体数组,直接传递images

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用JNA调用SO库,需要注意传递参数的数据类型和内存布局,以确保传递的参数正确无误。 对于一个结构体数组,我们可以使用JNA的`Structure`类来表示,同在定义结构体,需要使用`@Field`注解来指定字段在内存中的偏移量和数据类型。 对于整型二维数组中的负数问题,可以在定义结构体,使用无符号整型`int`来表示,这样可以确保数据不会出现负数。 具体的代码实现可以参考以下示例: ```java import com.sun.jna.Structure; import com.sun.jna.ptr.PointerByReference; import java.util.Arrays; import java.util.List; public class MyLibrary { public static class MyStruct extends Structure { public int[][] intArray; public MyStruct(int[][] intArray) { this.intArray = intArray; } public static class ByReference extends MyStruct implements Structure.ByReference { public ByReference(int[][] intArray) { super(intArray); } } @Override protected List getFieldOrder() { return Arrays.asList("intArray"); } @Override protected java.util.Map<String, Object> getFieldOrderMap() { java.util.Map<String, Object> map = super.getFieldOrderMap(); map.put("intArray", int[][].class); return map; } public static MyStruct[] toArray(PointerByReference pbr, int length) { return (MyStruct[])Structure.toArray(pbr, length); } } public static native void myFunction(MyStruct[] structArray, int length); } ``` 在上述代码中,`MyStruct`表示一个结构体,其中包含一个整型二维数组`intArray`。`MyStruct.ByReference`表示一个指向结构体的指针,用于传递给SO库中的函数。 在`MyStruct`中,我们重写了`getFieldOrder`和`getFieldOrderMap`方法,用于指定结构体中的字段顺序和数据类型。 在`MyStruct.toArray`方法中,我们使用`Structure.toArray`将指向结构体数组的指针转换为Java中的结构体数组。 在使用JNA调用SO库的过程中,需要注意使用相应的数据类型和内存布局,以确保传递的参数正确无误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值