2015-05-21 9 views
5

Ich habe einen Fehler, wenn ich Android-App, die ich benutze JNI-Funktionen und C++ Code in es. Wenn es läuft, bekam ich folgende Meldung:Ich erhalte Fehlermeldung, wenn JNI Android App A/libc: Fatal Signal 11 (SIGSEGV) bei 0xdeadddd (Code = 1), Thread 17729

Fatal Signal 11 (SIGSEGV) bei 0xe480001d (code = 1), Gewinde 5465

Und schließlich meine Codes hier:

JNIEXPORT jstring JNICALL Java_ir_bassir_ndktest4_MainActivity_getName 
(JNIEnv *env, jobject obj){ 

    jclass cls = (*env)->GetObjectClass(env, obj); 
    jmethodID mid = (*env)->GetStaticMethodID(env, cls, "testJava", "([Ljava/lang/String)[Ljava/lang/String"); 

    jstring plainText = (*env)->NewStringUTF(env, "Hello from JNI ! Compiled with ABI 2222 "); 
    jstring result = (*env)->CallStaticObjectMethod(env, cls, mid, plainText); 

    return (*env)->NewStringUTF(env, plainText); 
} 

und auf der Java-Seite:

public class MainActivity extends ActionBarActivity { 

    public native String getName(); 

    public static String testJava(String txt){ 
     Log.d("BP","call back to java method"); 
     String result = txt + "its added in JAVA"; 
     return result; 
    } 

    static{ 
     System.loadLibrary("HelloJNI"); 
    } 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 
     String name = getName(); 

     Log.d("BP",name); 
    } 

    @Override 
    public boolean onCreateOptionsMenu(Menu menu) { 
     // Inflate the menu; this adds items to the action bar if it is present. 
     getMenuInflater().inflate(R.menu.menu_main, menu); 
     return true; 
    } 

    @Override 
    public boolean onOptionsItemSelected(MenuItem item) { 
     // Handle action bar item clicks here. The action bar will 
     // automatically handle clicks on the Home/Up button, so long 
     // as you specify a parent activity in AndroidManifest.xml. 
     int id = item.getItemId(); 

     //noinspection SimplifiableIfStatement 
     if (id == R.id.action_settings) { 
      return true; 
     } 

     return super.onOptionsItemSelected(item); 
    } 
} 

Antwort

3

die JNI Seite dieses Codes ist C, nicht C++ und laxe Handhabung des C von poi Späteres Punning ist Teil des Problems. Ihr Code bricht auf diesen beiden Linien:

jstring plainText = (*env)->NewStringUTF(env, "Hello from JNI ! Compiled with ABI 2222 "); 
return (*env)->NewStringUTF(env, plainText); 

weil NewStringUTF die Signatur hat

jstring NewStringUTF(JNIEnv *env, const char *bytes); 

was bedeutet, dass dieser Anruf unterbrochen wird:

//      vvvvvvvvv--- plainText is not of the right type! 
(*env)->NewStringUTF(env, plainText) 

Der C-Compiler akzeptiert es, weil jstring ist ein Zeigertyp (ein C++ - Compiler würde nicht), so plainText wird als char const * interpretiert, die weitergeht, um dumme Dinge zu tun.

Wie auch immer, ich vermute, dass Sie

return result; 

... sagen wollte, aber wenn Sie gemeint plainText zurückzukehren, sagen Sie einfach

return plainText; 

Es gibt keine Notwendigkeit, eine Kopie zu machen.

+0

Mit Vielen Dank für Ihre Antwort Wintermute. Aber es gab einen weiteren Fehler in meinem Code, den ich korrigiere und in die nächste Antwort lege. –

1

Es ist richtig Reihe von Code hier:

JNIEXPORT jstring JNICALL Java_ir_bassir_ndktest4_MainActivity_getName (JNIEnv *env, jobject obj) { 
    jclass cls = (*env)->GetObjectClass(env, obj); 
    jmethodID mid = (*env)->GetStaticMethodID(env, cls, "testJava", "(Ljava/lang/String;)Ljava/lang/String;"); 

    jstring plainText = (*env)->NewStringUTF(env, "Hello from JNI ! Compiled with ABI 2222 "); 
    jstring result = (*env)->CallStaticObjectMethod(env, cls, mid, plainText); 
    return result; 
}