什么情况下需要释放局部引用对象:
1.访问一个很大的java对象,使用完之后,还要进行复杂的耗时操作
2.创建了大量的局部引用,占用了太多的内存,而且这些局部引用跟后面的操作没有关联性
// 在jni中告知虚拟机回收一个jni对象,在局部引用中通过DeleteLocalRef()来释放内存
//循环创建数组,
JNIEXPORT void JNICALL Java_com_example_jnitest_MainActivity_localRef
(JNIEnv *env, jobject jobj){
int i = 0;
for (; i < 7; ++i) {
//创建date对象
jclass cls = (*env)->FindClass(env,"java/util/Date");
jmethodID method = (*env)->GetMethodID(env,cls,"<init>","()V");
jobject date = (*env)->NewObject(env,cls,method);
//如果不在使用局部date对象,通知垃圾回收器对date对象进行回收,
(*env)->DeleteLocalRef(env,date);
}
}
全局引用
释放全局引用对象调用函数:DeleteGlobalRef(),释放完之后,再此获取全局引用就会抛异常,所以这个需要注意哦
jstring global_str;
//全局引用
JNIEXPORT void JNICALL Java_com_example_jnitest_MainActivity_createGlobalRef
(JNIEnv *env, jobject jobj){
jstring j_str = (*env)->NewStringUTF(env,"liutian is beautiful");
//NewGlobalRef 把局部变量提升为全局引用
global_str = (*env)->NewGlobalRef(env,j_str);
};
JNIEXPORT jstring JNICALL Java_com_example_jnitest_MainActivity_getGlobalRef
(JNIEnv *env, jobject jobj){
//获取全局对象
return global_str;
}
JNIEXPORT void JNICALL Java_com_example_jnitest_MainActivity_deleteGlobalRef
(JNIEnv *env, jobject jobj){
//释放全局内存
(*env)->DeleteGlobalRef(env,global_str);
}