我收到错误信息,当运行JNI安卓应用程序A/libc﹕致命信号11(SIGSEGV)在0xdeadd00d(代码=1),线程17729

 2023-01-20    301  

问题描述

运行Android应用程序时,我会在其中使用JNI函数和C ++代码.运行时,我得到了下面的消息:

致命信号11(sigsegv)在0xe480001d(代码= 1),线程5465

我收到错误信息,当运行JNI安卓应用程序A/libc﹕致命信号11(SIGSEGV)在0xdeadd00d(代码=1),线程17729

最后是我的代码:

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);
}

和爪哇一侧:

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);
    }
}

推荐答案

此代码的JNI侧是C,而不是C ++,C的Laxer对指针的处理是问题的一部分.您的代码在这两行上断开:

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

因为NewStringUTF具有签名

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

这意味着此呼叫被打破:

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

C编译器接受它是因为jstring是指指指针类型(C ++编译器不会),因此plainText将被解释为char const *,它继续做愚蠢的事情.

无论如何,我怀疑你打算说

return result;

…但是,如果您打算返回plainText,请说

return plainText;

无需制作副本.

其他推荐答案

这里有正确的代码:

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;}

以上所述是小编给大家介绍的我收到错误信息,当运行JNI安卓应用程序A/libc﹕致命信号11(SIGSEGV)在0xdeadd00d(代码=1),线程17729,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对77isp云服务器技术网的支持!

原文链接:https://77isp.com/post/26024.html

=========================================

https://77isp.com/ 为 “云服务器技术网” 唯一官方服务平台,请勿相信其他任何渠道。