在java層有一個帶參數的方法:public void test(int i){ Log.d("Test",i)}然后聲明了一個native方法:public native void nativeTest();JNI層:我使用的是非靜態調用(其中"java_obj"之前已實例化)JNIEXPORT void JNICALL Java_aaa_bbb_CCC_nativeTest (JNIEnv * env, jobject obj, jint index){ /*獲得類名*/ jclass java_class = env->FindClass("aaa/bbb/CCC"); if (java_class == 0){ LOGE("not find class!"); return; } /*判斷對象是否存在*/ if (java_obj == 0){ LOGE("not find java OBJ!"); return; } /*獲取類中的方法*/ jmethodID java_method = env->GetMethodID(java_class, "test", "(I)V"); if(java_method == 0){ LOGE("not find java method!"); return; } /*調用方法*/ env->CallVoidMethod(java_obj, java_method, index);}重點來了,我在另一個cpp調用上述方法時,運行沒問題,也能打出log,但是當該方法被調用多次時(大約10多次),內存泄露。最終我將錯誤鎖定在上述紅色字體部分,因為當我沒有調用CallVoidMethod,啥問題都沒有。
如果說java方法有問題,于是我寫了一個空的java方法,調用10多次后,還是會報錯?為什么
12345678_0001
2023-03-18 17:13:45
