我试图将一个原始浮点数组从c传递(即复制)到java。包含源数组的c结构:
struct foo_cpp {
float a[16];
};
包含目标数组的java类:
public class foo_java {
public float a[];
public foo_java() {
a = new float[16];
}
}
试图将数据传递给java类的c++函数:
extern "C" JNIEXPORT jobject JNICALL Java_com_example_myapp_Controller_process_1frame(JNIEnv *env, jclass clazz)
{
// C++ "source array"
foo_cpp fc;
// Initialize fc.a here...
// Convert from cpp to java
jobject foo_object;
{
// Create the foo object
jclass foo_class_id = env->FindClass("com/example/myapp/foo_java");
jmethodID foo_ctor_id = env->GetMethodID(foo_class_id, "<init>", "()V");
foo_object = env->NewObject(foo_class_id, foo_ctor_id);
// Get the field ID
jfieldID field_id = env->GetFieldID(foo_class_id, "a", "[F");
// Set the fields
{
// Get pointer to Java object float array (Get pointer to Java class foo_java::a)
jobject field_data = env->GetObjectField(foo_object, field_id);
jfloatArray *fa = reinterpret_cast<jfloatArray*>(&field_data);
float *fa_raw = env->GetFloatArrayElements(*fa, nullptr);
for (int i = 0; i < 16; i++)
fa_raw[i] = static_cast<float>(fc.a[i]);
}
}
return foo_object;
}
但是,在运行这个命令时,java对象中的值并不像预期的那样。
我错过了什么/做错了什么?
1条答案
按热度按时间erhoui1w1#
问题中提到的代码结果和预期的一样有效。浮点值是正确的,这是一个典型的误解/分层问题。
然而,正如@michael在评论中指出的:一个
ReleaseFloatArrayElements()
是防止内存泄漏所必需的。