在android下面使用jni来调用c++,在开发游戏是非常正常的。但是要调试c++部分却是非常麻烦的问题。如果快速定位崩溃位置呢。NDK提供了一个小工具ndk-stack.

首先,我们先配置环境,把NDK路径和adb的路径配置到环境变量中。如下面:

ADBPATH = F:\DevelopTools\adt-bundle-windows-x86_64-20131030\sdk\platform-tools

NDKROOT = F:\DevelopTools\android-ndk-r9d

Path = %path%;%NDKROOT %;%ADBPATH%;

接下, 去我们到工程的根目录,执行以下命令:

adb logcat | ndk-stack -sym obj/local/armeabi

开始执行调试游戏,出现下列错误

********** Crash dump: **********
Build fingerprint: 'generic/sdk/generic:2.3.3/GRI34/101070:eng/test-keys'
pid: , tid: >>> com.example.hellojni <<<
signal (SIGSEGV), code (SEGV_MAPERR), fault addr
Stack frame I/DEBUG ( ): # pc 00000eb0 /data/data/com.examp
ringFromJNI at C:\Users\zhangchuanwei\workspace1\hellojni/jni/hellojni.cpp:
Stack frame I/DEBUG ( ): # pc 00017d74 /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 00048f08 /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 00041ab6 /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 0002976c /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 0005f5de /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 00066fce /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 0001cfd4 /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 000220dc /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 00020fd0 /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 0005f430 /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 0004b9a8 /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 0003ebb0 /system/lib/libdvm.s
Stack frame I/DEBUG ( ): # pc 000314ac /system/lib/libandro
Stack frame I/DEBUG ( ): # pc 000322c6 /system/lib/libandro
Stack frame I/DEBUG ( ): # pc 00008ca2 /system/bin/app_proc
Stack frame I/DEBUG ( ): # pc 00014db8 /system/lib/libc.so

直接可以看到我们的工程第22行有错误,看下22行是什么

    struct strTest{
char* pstr;
};
strTest *ptest=NULL;
ptest->pstr=NULL;
return env->NewStringUTF("hello world returned.");

对于ndk-stack的使用可以看ndk根目录下的docs/NDK-STACK.html文件

源码:http://files.cnblogs.com/chuanwei-zhang/hellojni-dynamic.zip

static const char* className = "com/example/hellojni/MainActivity";
JNIEXPORT jstring JNICALL stringFromJNI(JNIEnv* env, jclass clazz)
{
//return env->NewStringUTF(env, "Hello form JNI!");
struct strTest{
char* pstr;
};
strTest *ptest=NULL;
ptest->pstr=NULL;
return env->NewStringUTF("hello world returned.");
}

下载源码,并替换hellojni.cpp里面的上面这个函数,就可以重现上面问题了。

ndk-stack 调试 android c++ 代码崩溃位置的更多相关文章

  1. ida 调试 android fork

    在使用ida 调试android native代码时经常会碰见fork子进程的情况出现,而运行一个 android_server只能对一个进程进行调试或者attach,而ida 默认端口是23946, ...

  2. Linux内核:分析coredump文件 - 内核代码崩溃

    转自:http://blog.csdn.net/guowenyan001/article/details/12975221 一.分析Core文件 1.1 找到core文件目录,启动mycrash:my ...

  3. Eclipse+CDT+GDB调试android NDK程序(转)

    Eclipse+CDT+gdb调试android ndk程序 先介绍一下开发环境,在这个环境下,up主保证是没有问题的. ubuntu 11.10 eclipse 3.7(indego) for ja ...

  4. Android Studio代码调试大全

    http://blog.csdn.net/dd864140130/article/details/51560664 Android Studio目前已经成为开发android的主要工具,用熟了可谓相当 ...

  5. Ubuntu18.04上使用LLDB调试Chromium Android C++代码。

    ###动机###Chromium Android源代码庞大且复杂.在调试器LLDB下能帮助我们更好的理解代码流程.介绍使用LLDB调试器调试android上chromium的C++代码. [1] 编译 ...

  6. JS事件调试 - 查找HTML元素绑定的事件以及绑定代码所在位置

    日常的网页开发调试工作中,经常需要知道指定的某个网页元素绑定了哪些事件以及绑定代码的位置,下面介绍三种用来跟踪页面中的事件的方法. 1.使用firefox调试 我们可以使用firefox的debug工 ...

  7. Android Native 代码NDK开发学习笔记

    引用:http://www.kunli.info/2011/08/21/android-native-code-study-note/ JNI,全称Java Native Interface,是用于让 ...

  8. Web程序员开发App系列 - 调试Android和IOS手机代码(补图)

    Web程序员开发App系列 Web程序员开发App系列 - 认识HBuilder Web程序员开发App系列 - 申请苹果开发者账号 Web程序员开发App系列 - 调试Android和iOS手机代码 ...

  9. Android如何完全调试framework层代码

    1 之前写过一篇文章:<Android实现开机调试system_process> 2 google的eclipse插件ADT的已经能够很方便的调试Android的apk了,但是调试的时候应 ...

随机推荐

  1. vue数据源转json问题

    开发过程中使用到了vue框架进行前端批量数据的处理,将批量数据转换为json格式进行ajax传参时需要注意将vue数据源得到的json结果进行如下处理,webservice接收json数据时无法有效的 ...

  2. 10、桥接模式(Bridge)

    桥接模式就是把事物和其具体实现分开,使他们可以各自独立的变化.桥接的用意是:将抽象化与实现化解耦,使得二者可以独立变化,像我们常用的JDBC桥DriverManager一样,JDBC进行连接数据库的时 ...

  3. Logcat过滤及常见用法整理

    Usage: logcat [options] [filterspecs] options include:-s              Set default filter to silent.  ...

  4. idx_rebuild_diff_idx_l.sql

    1. set echo on feedback on set timing on set time on set pagesize 1000 set linesize 150 spool 02_do_ ...

  5. Android------三种监听OnTouchListener、OnLongClickListener同时实现即其中返回值true或者false的含义

    引自:http://5200415.blog.51cto.com/3851969/1003113 android应用中常用的监听OnTouchListener.OnClickListener.OnLo ...

  6. SDAU课程练习--problemC

    题目描述 Here is a famous story in Chinese history. "That was about 2300 years ago. General Tian Ji ...

  7. 签名“未签名”apk文件命令

    在发布至360.oppo应用市场时分别遇到了需要"应用加固"和"应用认领"的情况, 流程都是需要下载一个未签名的apk文件(安装包),然后签名后再上传. 我的做 ...

  8. Tickets 基础DP

    Tickets Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Sub ...

  9. jdb

    http://herongyang.com/jtool/jdb.html http://www.rhcedan.com/2010/06/22/killing-a-java-thread/ 用处:上去杀 ...

  10. openssl使用+Demo

    1. websiteSSL(secure Socket Layer)TLS(transport Layer Security) - SSL3.0基础之上提出的安全通信标准,目前版本是1.0openss ...