android - NDK 一般段错误,decStrong?

标签 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)

虽然所需的按钮按下次数似乎是随机的,但此错误最终确实会发生。 native 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;

}

随机性是一个随机数生成器,当前仅返回一个常量。

有人熟悉这个问题吗?

最佳答案

您确定在这里吗:

randomResult = malloc(sizeof(szFormat) + 20);

你分配了足够的内存吗? sizeof(szFormat) 将返回 4。

还有什么是JNIEnv? 此符号 -> 通常与指针一起使用,在您的情况下,您首先取消引用 env,然后仍然应用 ->

关于android - NDK 一般段错误,decStrong?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28415187/

相关文章:

android - React Native Android 应用程序在启动时崩溃

c - 如何检查非阻塞匿名管道是否有数据而不删除它

捕获操作码 0xCC 作为异常

android - Honeycomb 以下的 Android 不支持 Bytebuffer array() 方法

android - 当我尝试将 mobile-center-push 添加到 React Native 项目时找不到 com.google.firebase :firebase-core:11. 0.0

java - 两个android设备如何通信?

android - Mobilefirst 7.1 中带有状态栏的推送通知

c - 在 Windows 10 上安装 GTK for c?

Android NDK : Multiple definition of . o 和 .c 文件

android - 如何从 armeabi 以外的位置加载共享对象?