Android NDK对象的引用-全局引用,局部引用,弱引用

原创
2015/01/12 23:55
阅读数 849

百度了一下,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;
	}
}



展开阅读全文
加载中
点击引领话题📣 发布并加入讨论🔥
打赏
0 评论
0 收藏
1
分享
返回顶部
顶部