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