============================================================
博文原创,转载请声明出处
电子咖啡(原id蓝岩)
============================================================
分享一段JNI子线程中调用Java静态方法的代码,并传递byte数组,实际测试可以使用的。
JNIEnv *env;
jmethodID mid;
//JNI子线程不能直接调用java方法,只能调用static方法
//Attach主线程 g_jvm 是JavaVM*
if(g_jvm->AttachCurrentThread(&env, NULL) != JNI_OK)
{
LOGE("%s: AttachCurrentThread() failed", __FUNCTION__);
return NULL;
}
//找到对应的类
if(cls==NULL){
cls = env->GetObjectClass(g_obj);
}
if(cls == NULL)
{
LOGE("FindClass() Error.....");
}
//找到对应的静态方法
mid = env->GetStaticMethodID(cls, "JdisPlay", "([BII)V");
if (mid == NULL)
{
LOGE("FindClass() Error.....");
}
int len=mWidth*mHeight*3/2;
jint w=mWidth;
jint h=mHeight;
LOGE("width = %d and height=%d",w,h);
//创建新byte数组,注意:稍后释放
jbyteArray byteArr = (env)->NewByteArray(len);
//以下三行是将C byte数组转换为java byte[]
jboolean isCopy;
void *data = env->GetPrimitiveArrayCritical((jarray)byteArr, &isCopy);
memcpy(data, mOutputFrameBuffer, len);
//调用静态方法
env->CallStaticVoidMethod(cls, mid, byteArr,w,h);
//最后需要释放我们的array,否则内存泄露
(env)->ReleasePrimitiveArrayCritical(byteArr, data, JNI_ABORT);
(env)->DeleteLocalRef(byteArr);