通过 JNI 将浮点数 [][] 传递给C++的最简单方法

2022-09-03 06:17:06

在我的Java代码中,我有一个2D浮点数组。此处可以介于 1 和 25 之间。我必须通过将此2D浮点数组传递给方法。我的方法是float[x][4] floatArrayxC++JNIJNI

jboolean MyJNIMethod(JNIEnv * env, jobject obj, jobjectArray myArray)
{
    //how to convert this myArray to something that can be safely passed to C++ method below
}

在里面,我必须调用一个方法,并将从Java获取的2D浮点数组传递给此方法MyJNIMethodC++

bool MyCplusPlusMethod(float coordinates[][4])
    {

    }

由于缺乏原生开发知识,我很难将 jobject 正确转换为 float[][]。谁能告诉我最简单,最安全的方法?谢谢


答案 1

像这样的东西应该工作:

jboolean MyJNIMethod(JNIEnv * env, jobject obj, jobjectArray myArray)
{
  int len1 = env -> GetArrayLength(myArray);
  jfloatArray dim=  (jfloatArray)env->GetObjectArrayElement(myArray, 0);
  int len2 = env -> GetArrayLength(dim);
  float **localArray;
  // allocate localArray using len1
  localArray = new float*[len1];
  for(int i=0; i<len1; ++i){
     jfloatArray oneDim= (jfloatArray)env->GetObjectArrayElement(myArray, i);
     jfloat *element=env->GetFloatArrayElements(oneDim, 0);
     //allocate localArray[i] using len2
     localArray[i] = new float[len2];
     for(int j=0; j<len2; ++j) {
        localArray[i][j]= element[j];
     }
  }
  //TODO play with localArray, don't forget to release memory ;)
}

请注意,这是大纲。它不会编译;)(我在这个超堆编辑器中写了它)

在你的类中,你应该声明本机方法:

 public native void myJNIMethod(float[][] m);

并在您的c代码中对应:

JNIEXPORT jboolean JNICALL Java_ClassName_methodName (JNIEnv *, jobject, jobjectArray);

下面是 JNI 数组操作文档


答案 2

要释放分配的内存,您可以执行如下操作:

static void releaseMatrixArray(JNIEnv *env, jobjectArray matrix) {
int size = (*env)->GetArrayLength(env, matrix);
for (int i = 0; i < size; i++) {
    jfloatArray oneDim = (jfloatArray) (*env)->GetObjectArrayElement(env, matrix, i);
    jfloat *elements = (*env)->GetFloatArrayElements(env, oneDim, 0);

    (*env)->ReleaseFloatArrayElements(env, oneDim, elements, 0);
    (*env)->DeleteLocalRef(env, oneDim);
  }
}

发布本地数组引用:

free(localArray);

推荐