java - 我在运行 JNI android 应用程序 A/libc 时收到错误消息:致命信号 11 (SIGSEGV) 在 0xdeadd00d(代码=1),线程 17729

标签 java android c++ java-native-interface native

当我运行在其中使用 JNI 函数和 C++ 代码的 Android 应用程序时出现错误。当它运行时,我收到以下消息:

Fatal signal 11 (SIGSEGV) at 0xe480001d (code=1), thread 5465

最后是我的代码:

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

在 Java 方面:

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 对指针双关的较宽松处理是问题的一部分。您的代码在这两行中断:

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;

无需复制。

关于java - 我在运行 JNI android 应用程序 A/libc 时收到错误消息:致命信号 11 (SIGSEGV) 在 0xdeadd00d(代码=1),线程 17729,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30368236/

相关文章:

java - OpenCMS - 301 重定向

java - 为什么 Java 8's functional-style constructs called "流”?

android - 带有相机预览的 SurfaceView 未被破坏

android - 旋转位图 - Android

java - 如何在 Android 应用程序中保留我的主题设置?

java - 屏幕键盘 JButton 完全适合文本大小

java - 无法将 SonarQube 从 4.5.2 升级到 5.0

c++ - freopen 不适用于 C 标准输入

c++ - TCHAR 指针初始化

c++ - 如何很好地输出分隔字符串列表?