jni c調用java 方法封裝後出現的問題

兩種解決方案:

若是封裝函數後再調用java層函數時就會出現錯誤方法一是採用將java函數改爲靜態方法;

(1)

java 層函數原型

    public  static void JavaTest(int  x ,int  y ,int size)       
    {
        
        Log.e("JavaTest", "x="+x+"y="+y+"size="+size);
          
    }  
   

首先定義路徑:

紅的部分是       包名/類名

static const char *classPathName = "com/example/myjni/MyNativeLib";

c層的方法

jmethodID     c_jmothods;


         jclass clazz =env->FindClass(classPathName);
        if (clazz  == NULL)
        {
            LOGE("clazz  == NULL");
        }
        else
        {
            c_jmothods =    env->GetStaticMethodID(clazz, "JavaTest","(III)V");
           
        }


        if (c_jmothods == NULL)
        {
            LOGE("c_jmothods  == NULL");

        }
        env->CallStaticVoidMethod(clazz,c_jmothods,110,11,112);
 

方法2:

可以不用改變原來的函數  及不需要時靜態方法


此時java 層函數原型

    public  void JavaTest(int  x ,int  y ,int size)       
    {
        
        Log.e("JavaTest", "x="+x+"y="+y+"size="+size);
          
    }  
   




        jclass clazz = env->FindClass(classPathName);
        jmethodID mid = env->GetMethodID(clazz, "<init>", "()V");
        jmethodID post_event = env->GetMethodID(clazz, "JavaTest", "(III)V");
        jobject jobt = env->NewObject(clazz, mid);


        env->CallVoidMethod(jobt, post_event, 100,99,199);






發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章