SIGSEGV Android JNI空方法

时间:2017-11-12 00:33:40

标签: java android c android-ndk java-native-interface

我遇到了非常奇怪的问题,我不知道出了什么问题,因为我已经注释掉了所有内容,但它仍然崩溃了。

这是我的代码

Java部分

package net.example.library.arrayprocessor;


public class ArrayProcessor {
    static {
        System.loadLibrary("array-processor");
    }

    public ArrayProcessor() {

    }

    public native short[] process(short[] readBuffer);

}

我称之为

   buffer = arrayProcessor.process(buffer);

JNI部分 CMake的

# Cmake Minimum Version
cmake_minimum_required(VERSION 3.4.1)

add_library(array-processor SHARED
            processor.cpp)
# Link
target_link_libraries(
            array-processor
            android
            log)

processor.cpp

#include <jni.h>
#include <stdio.h>

#define LOGI(...) \
  ((void)__android_log_print(ANDROID_LOG_INFO, "VoiceProcessor::", __VA_ARGS__))

extern "C" {
JNIEXPORT jshortArray JNICALL
Java_net_example_library_arrayprocessor_ArrayProcessor_processor(
        JNIEnv *env, jobject instance, jshortArray readBuffer_);
}

JNIEXPORT jshortArray JNICALL
Java_net_example_library_arrayprocessor_ArrayProcessor_processor(
        JNIEnv *env, jobject instance, jshortArray readBuffer_) {

  /* get size of the array */
  jsize len = env->GetArrayLength(readBuffer_);

  /* get the body of array; it will be referecende by C pointer */
  jshort *body = env->GetShortArrayElements(readBuffer_, 0);

  /* do some stuff */
  for (int i = 0; i < len; i++) {
    printf("Short value: %hd\n", body[i]);

    /* update value */
    body[i] = 0;
  }

  /* release body when you decide it is no longer needed
    Pass changes back to Java */
  env->ReleaseShortArrayElements(readBuffer_, body, JNI_COMMIT);
}

但是当我尝试调用它时会抛出错误

 A/libc: Fatal signal 11 (SIGSEGV) at 0xc0c5a8f7 (code=1), thread 19335 (pool-3-thread-1)

我试图注释掉该方法的主体,但仍然是同样的错误。

   A/libc: Fatal signal 11 (SIGSEGV), code 1, fault addr 0x6 in tid 3749 (pool-4-thread-1)

我的代码有什么问题?如何解决和调试这些问题?

我将不胜感激任何帮助

1 个答案:

答案 0 :(得分:1)

您没有返回值。您可以返回readBuffer_,但如果所有操作都修改输入数组,则该方法根本不需要返回值。它可以声明为void

C编译器应该至少警告过你。不要忽略警告,也不要将其关闭。 JNI代码必须干净利落。