天天看點

android JNI 多線程調用與回調

說明: JNI調用比較簡單,根據JNI給出的執行個體,本内容主要講多線程使用回調步驟:

1.  編寫說明,調用JNI類。兩種方法:

   1)通過包+類名找到

         static jclass jNativesCls;

         #define CB_CLASS "org/piaozhiye/study/Natives"

         jNativesCls = (*env)->FindClass(env,CB_CLASS);

    2) 通過 JNIEXPORT jint JNICALL Java_org_piaozhiye_study_Natives_LibMain

  (JNIEnv * env, jclass class);取得其中的class。 唯一差別就是要求調用的函數與回調函數在相同類中

2. 編寫回調函數  ,如果不太懂得寫,可以寫個接口,然後用javah 生成,再抄寫

       #define CB_CLASS_MSG_CB "OnMessage"    // 函數名

      #define CB_CLASS_MSG_SIG "(Ljava/lang/String;I)V"   //參數與傳回值

     jmethodID  mSendStr = (*env)->GetStaticMethodID(env,jNativesCls,CB_CLASS_MSG_CB,CB_CLASS_MSG_SIG);  // 取得方法ID

     注意: 在使用時,每次調用時需要加上這句

               (*g_VM)->AttachCurrentThread(g_VM,&env,NULL);   //附加到目前線程中, 生成 env

              (*env)->CallStaticVoidMethod(env,jNativesCls,mSendStr,(*env)->NewStringUTF(env,text),(jint)level); //再進行使用,若不同線程,env則不相同,造成調用出錯

3. 碰到的報錯:

    1) JNI ERROR (app bug): accessed stale local reference 0x50100019  不同線程回調時報的錯,這錯誤排查一整天,終于找到了,是由于Mamifest.xml 配置問題造成的,把uses-sdk配置改成這樣: <uses-sdk android:minSdkVersion="7" />