百度了一下,google了一下,关于NDK引用的介绍无10篇中就有9.9篇是相同的,对于这种问题,我只能呜呼哀哉了!!
局部引用(函数内部对象类型变量):在C或C++中,局部变量表示只运行范围局限在该变量最近的 “{}”花括号里,常见的就是函数中的变量了,但局部引用和局部变量不同了,引用的主体是对象,指针,
因此,设涉及到内存回收问题。同局部变量一样,局部对象在函数执行完成后会被立即销毁。
(错误的用法1:将局部引用赋值给全局引用或弱引用)
(错误的用法 : 引用被静态缓存,这种方法十分危险,容易导致程序蹦退,但不是不可以,只是引用的主题必须不是对象才行,比如jfieldID,jmethodID等)
JNIEXPORT void JNICALL Java_com_ndk_cjava_exchange_UserEntity_referenceUnit
(JNIEnv * env, jobject thiz)
{
static jfieldID nameField = NULL;
if(nameField==NULL)
{
nameField = env->GetFieldID(clazz,"name","Ljava/lang/String;");
}
//do somthing
}
全局引用(函数外部对象类型变量):全局引用表示把局部引用通过某种方式复制给全局对象,并且该变量不会自动销毁,需要手动销毁
jclass globalJclazz = NULL;
JNIEXPORT void JNICALL Java_com_ndk_cjava_exchange_UserEntity_referenceUnit
(JNIEnv * env, jobject thiz)
{
if(globalJclazz==NULL)
{
__android_log_print(ANDROID_LOG_INFO,"REF","--1-->");
globalJclazz = (jclass)(env->NewGlobalRef(env->GetObjectClass(thiz))); //转为全局引用
}else{
__android_log_print(ANDROID_LOG_INFO,"REF","--2-->");
env->DeleteGlobalRef(globalJclazz);
globalJclazz =NULL;
}
}
弱引用:作用域同全局变量一样,但不能保证该引用一致从在,当内存不足时会自动销毁
jclass weakclass = NULL;
JNIEXPORT void JNICALL Java_com_ndk_cjava_exchange_UserEntity_referenceUnit
(JNIEnv * env, jobject thiz)
{
if(weakclass==NULL || (env->IsSameObject(weakclass,NULL))==JNI_TRUE)
{
jclass jclzz = env->GetObjectClass(thiz);
weakclass = (jclass)(env->NewWeakGlobalRef(jclzz));
}else{
env->DeleteWeakGlobalRef(weakclass);
weakclass = NULL;
}
}