NDK一般分段故障,decStrong?

时间:2015-02-09 17:03:05

标签: android c android-ndk segmentation-fault

我在Android NDK上遇到了一个非常奇怪的分段错误,但它不是一直发生的。我想在输入时问你们,如果没有,那么我会尝试将此报告为错误。

我在与执行C代码相关的应用程序上按下按钮。按钮和C代码有效,但我注意到在多次按下后,会出现分段错误:

01-05 19:36:08.723  27256-27267/com.example.developer.addc A/libc﹕ Fatal signal 11 (SIGSEGV) at 0xb8c80677 (code=1), thread 27267 (Binder_1)

我在logcat输出上使用ndk-stack运行了堆栈跟踪,看到了这个:

********** Crash dump: **********
Build fingerprint: 'samsung/klteuc/klteatt:4.4.2/KOT49H/G900AUCU1ANCE:user/release-keys'
pid: 28204, tid: 28217, name: Binder_2  >>> com.example.developer.addc <<< signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr b8dedddf
Stack frame #00  pc 0000d176  /system/lib/libutils.so(android::RefBase::decStrong(void const*) const+3)
Stack frame #01  pc 0001cfef  /system/lib/libbinder.so(android::IPCThreadState::processPendingDerefs()+82)
Stack frame #02  pc 0001db0f  /system/lib/libbinder.so (android::IPCThreadState::joinThreadPool(bool)+42)
Stack frame #03  pc 00021965  /system/lib/libbinder.soStack frame #04  pc0000ea5d  /system/lib/libutils.so (android::Thread::_threadLoop(void*)+216)
Stack frame #05  pc 00055f41  /system/lib/libandroid_runtime.so android::AndroidRuntime::javaThreadShell(void*)+68)
Stack frame #06  pc 0000e58f  /system/lib/libutils.so Stack frame #07  pc 0000d298  /system/lib/libc.so (__thread_entry+72)
Stack frame #08  pc 0000d430  /system/lib/libc.so (pthread_create+240)

虽然按下按钮的次数似乎是随机的,但这种错误最终会一直发生。本机c代码是:

#include <jni.h>
#include <string.h>
#include <stdio.h>
#include <android/log.h>
#include "randomNumbers.h"
#define DEBUG_TAG "NDK_Tutorialapp"

jstring Java_com_example_developer_addc_MainActivity_getNumber(JNIEnv * env, jobject this, jint value1)

{
char *szFormat = "The random number is: %i";
char *randomResult;


int sum = randomness(value1);

randomResult = malloc(sizeof(szFormat) + 20);
jstring result;
if(randomResult!=NULL){
    sprintf(randomResult, szFormat, sum);
    result = (*env)->NewStringUTF(env, randomResult);
    free(randomResult);
}
return result;

}

和randomness是一个随机数生成器,目前只返回一个常量。

有谁熟悉这个问题?

1 个答案:

答案 0 :(得分:1)

你确定在这里:

randomResult = malloc(sizeof(szFormat) + 20);
你分配了足够的内存吗? sizeof(szFormat)将返回4.

同样是什么JNIEnv? 此标记->通常用于指针,在您的情况下,您首先取消引用env,然后仍然应用->

相关问题