`

【翻译】(23)NDK Stack

 
阅读更多

-----------------

英文文档见android-ndk-r6b的documentation.html

属于Android Native Development Kit (NDK)的一部分

http://developer.android.com/sdk/ndk/index.html

翻译仅个人见解

-----------------

 

Android ndk-stack tool

 

Android ndk-stack工具

----------------------

 

Introduction:

 

介绍:

-------------

 

This document describes the 'ndk-stack' tool that is distributed with the Android NDK, since release r6.

 

本文档描述ndk-stack工具,它从发布版r6开始由Anroid NDK分发。

 

Overview:

 

概述:

---------

 

'ndk-stack' is a simple tool that allows you to filter stack traces as they appear in the output of 'adb logcat' and replace any address inside a shared library with the corresponding : values.

 

ndk-stack是一个简单工具,允许你过滤在adb logcat输出中显示的堆栈跟踪,并且把共享库内的任意地址替换成相应的冒号值(注:这里应该指<函数名><文件名>:<行号>格式,见下)

 

In a nutshell, it will translate something like:

 

简而言之,它将翻译好像这样子的东西:

 

    I/DEBUG   (   31): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***

    I/DEBUG   (   31): Build fingerprint: 'generic/google_sdk/generic/:2.2/FRF91/43546:eng/test-keys'

    I/DEBUG   (   31): pid: 351, tid: 351  %gt;%gt;%gt; /data/local/ndk-tests/crasher <<<

    I/DEBUG   (   31): signal 11 (SIGSEGV), fault addr 0d9f00d8

    I/DEBUG   (   31):  r0 0000af88  r1 0000a008  r2 baadf00d  r3 0d9f00d8

    I/DEBUG   (   31):  r4 00000004  r5 0000a008  r6 0000af88  r7 00013c44

    I/DEBUG   (   31):  r8 00000000  r9 00000000  10 00000000  fp 00000000

    I/DEBUG   (   31):  ip 0000959c  sp be956cc8  lr 00008403  pc 0000841e  cpsr 60000030

    I/DEBUG   (   31):          #00  pc 0000841e  /data/local/ndk-tests/crasher

    I/DEBUG   (   31):          #01  pc 000083fe  /data/local/ndk-tests/crasher

    I/DEBUG   (   31):          #02  pc 000083f6  /data/local/ndk-tests/crasher

    I/DEBUG   (   31):          #03  pc 000191ac  /system/lib/libc.so

    I/DEBUG   (   31):          #04  pc 000083ea  /data/local/ndk-tests/crasher

    I/DEBUG   (   31):          #05  pc 00008458  /data/local/ndk-tests/crasher

    I/DEBUG   (   31):          #06  pc 0000d362  /system/lib/libc.so

    I/DEBUG   (   31):

 

Into the more readable output:

 

变成更可读的输出:

 

    ********** Crash dump: **********

    Build fingerprint: 'generic/google_sdk/generic/:2.2/FRF91/43546:eng/test-keys'

    pid: 351, tid: 351  >>> /data/local/ndk-tests/crasher <<<

    signal 11 (SIGSEGV), fault addr 0d9f00d8

    Stack frame #00  pc 0000841e  /data/local/ndk-tests/crasher : Routine zoo in /tmp/foo/crasher/jni/zoo.c:13

    Stack frame #01  pc 000083fe  /data/local/ndk-tests/crasher : Routine bar in /tmp/foo/crasher/jni/bar.c:5

    Stack frame #02  pc 000083f6  /data/local/ndk-tests/crasher : Routine my_comparison in /tmp/foo/crasher/jni/foo.c:9

    Stack frame #03  pc 000191ac  /system/lib/libc.so

    Stack frame #04  pc 000083ea  /data/local/ndk-tests/crasher : Routine foo in /tmp/foo/crasher/jni/foo.c:14

    Stack frame #05  pc 00008458  /data/local/ndk-tests/crasher : Routine main in /tmp/foo/crasher/jni/main.c:19

    Stack frame #06  pc 0000d362  /system/lib/libc.so

 

Usage:

 

使用方法:

------

 

To do this, you will first need a directory containing symbolic versions of your application's shared libraries. If you use the NDK build system (i.e. ndk-build), then these are always located under $PROJECT_PATH/obj/local/<ab>, where <ab> stands for your device's ABI (i.e. 'armeabi' by default).

 

要做到这一点,你将首先需要一个包含你的应用程序的带符号版本的动态库的目录。如果你使用NDK构建系统(即ndk-build),那么它们总是位于$PROJECT_PATH/obj/local/<ab>目录下,这里<ab>是你的设备的ABI名称(即,默认是armeabi)。

 

You can feed the logcat text either as direct input to the program, e.g.:

 

你可以把logcat的文本作为直接的输入传给ndk-stack程序,例如:

 

   adb logcat | $NDK/ndk-stack -sym $PROJECT_PATH/obj/local/armeabi

 

Or you can use the -dump option to specify the logcat as an input file, e.g.:

 

或者你可以使用-dump开关指定logcat的输入文件,例如:

 

   adb logcat > /tmp/foo.txt

   $NDK/ndk-stack -sym $PROJECT_PATH/obj/local/armeabi -dump foo.txt

 

 

** IMPORTANT **:

 

** 重要事项 **:

 

  The tool looks for the initial line containing starts in the logcat output, i.e. something that looks like:

 

  这个工具会在logcat的输出内容中寻找包含开始内容的初始行,例如,如下所示的东西

 

    *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***

 

  When copy/pasting traces, don't forget this line from the traces, or ndk-stack won't work correctly.

 

  当复制/粘贴追踪内容,不要忘记追踪中的这一行,否则ndk-stack将不能正确工作。

 

TODO:

 

待完成:

-----

 

A future version of 'ndk-stack' will try to launch 'adb logcat' and select the library path automatically. For now, you'll have to do these steps manually.

 

未来的ndk-stack版本将尝试启动adb logcat并且自动地选择库目录。现在,你不得不手动地做这些步骤。

 

As of now, ndk-stack doesn't handle libraries that don't have debug information in them. It may be useful to try to detect the nearest function entry point to a given PC address (e.g. as in the libc.so example above).

 

到现在为止,ndk-stack不会去处理不带调试信息的库。它可能对尝试检测离给定PC地址最近的函数入口点有用(例如,上面例子中的libc.so)

 

分享到:
评论

相关推荐

    android ndk-stack使用说明。

    ### Android NDK-Stack 使用说明 #### 一、概述 在使用Cocos2d-x、JNI及Android NDK进行开发时,经常会遇到调试困难的问题。尤其是对于C/C++代码的调试,由于涉及到本地代码与Java层之间的交互,使得调试过程变得...

    ndk-stack调试 cocos2d-x

    ndk-stack 调试 cocos2d-x ndk-stack 是一个强大的命令行调试工具,用于调试 Native 代码,especially for Android 平台的.so 库文件。下面我们来详细了解 ndk-stack 在 cocos2d-x 中的应用。 什么是 ndk-stack? ...

    android Ndk开发用例

    - 使用`adb logcat`和`ndk-stack`工具分析崩溃日志,定位原生代码的错误。 - 优化方面,考虑使用JNI的`FindClass`, `GetMethodID`等方法缓存,减少JNI调用开销。 6. **安全与注意事项** - 原生代码可能会暴露...

    android-ndk-tracktrack-analyzer .py

    在实际使用中,开发者通常会结合`ndk-stack`工具来收集堆栈轨迹信息,然后利用"android-ndk-tracktrack-analyzer.py"进行后续分析。这个过程可能包括以下步骤: 1. **收集日志**:在设备上触发问题后,通过ADB...

    android-ndk(android-ndk-r26b-linux.zip)

    9. **崩溃日志和调试**:NDK提供了一些工具,如ndk-stack,帮助开发者分析和调试原生代码的崩溃日志,gdb则可用于原生代码的调试。 10. **多平台兼容性**:尽管这个版本是针对Linux的,NDK也提供了Windows和macOS的...

    CC2530NDK.rar_Z-STACK SensorDemo

    《CC2530NDK.rar_Z-STACK SensorDemo》是一个关于无线传感器网络开发的实践教程,主要基于CC2530芯片和Z-STACK协议栈。CC2530是一款由Texas Instruments(TI)公司生产的高效能、低功耗的微控制器,广泛应用于无线...

    android-ndk-r8dab.zip_NDK_android_android ndk

    8. **ndk-stack**: 用于符号化堆栈跟踪的工具,可以帮助开发者将崩溃报告中的内存地址转换为源代码行号,便于定位问题。 9. **ndk-which**: 类似于Linux下的`which`命令,用于查找NDK工具链中的可执行文件。 10. *...

    Android NDK开发Crash错误定位

    要定位NDK引发的崩溃问题,Android NDK提供了一些调试工具,包括addr2line、objdump和ndk-stack。这些工具可以帮助将崩溃的堆栈信息映射回具体的C/C++源代码位置。 addr2line工具可以将程序中的地址转换成对应的...

    DSP-NDK程序

    5. **协议栈库(STACK)** - 主要是TCP/IP网络栈,实现了从套接字层到底层链路层的所有功能。 - 构建在DSP/BIOS微操作系统之上,可以直接编译应用于DSP/BIOS OS,无需跨平台移植。 - 支持NIMU、VLANs、IPv6等功能...

    Android ndk

    4. **NDK工具**:如`ndk-build`、`ndk-gdb`(调试)、`ndk-stack`(堆栈回溯)等,辅助开发和调试原生代码。 ### 六、NDK的挑战和最佳实践 1. **调试难度**:本地代码的调试相比Java更复杂,需要使用`ndk-gdb`或...

    ollvm对ndk进行混淆的资源包

    4. **选择混淆策略**:OLLVM提供了多种混淆技术,如控制流扁平化(CFG)、跳转表(JOP)、栈保护(Stack Smashing Protector)等。根据项目需求选择合适的混淆策略,并通过编译选项传递给OLLVM。 5. **构建混淆原生...

    Android下各语言加callStack示例

    为了在Android设备上实际操作这些示例,你需要准备一个Android开发环境,安装NDK(用于C/C++)、JDK(用于Java)和必要的工具链。在你的项目中创建相应的C、C++、Java代码段,并确保正确配置编译选项。在运行时,...

    android_NDK.rar_NDK_android_android ndk_linux android

    - **性能分析**:使用Android Profiler和NDK提供的工具,如`ndk-stack`,可以对本地代码进行性能分析和错误排查。 5. **最佳实践** - **最小化本地代码**:只在必要时使用NDK,因为本地代码更难调试且不支持动态...

    android NDK 安装必备 Cygwin

    你还可以通过NDK的其他工具,如`ndk-gdb`进行调试,或者使用`ndk-stack`来分析崩溃日志。 总的来说,Cygwin作为Android NDK在Windows环境下的得力助手,使得开发者可以方便地进行原生代码的开发和调试工作,而无需...

    NDK User’s Guide (SPRU523)

    接下来,手册详细介绍了NDK栈库设计的理念、控制流程以及库的目录结构,包含STACK库、NETTOOL库、OS库、HALLibs以及NETCTRL库等。NDK栈库设计部分是针对开发者的高级指南,旨在帮助他们理解NDK的内部工作原理以及...

    TI Network Developer Kit (NDK)User‘s Guide中文版

    这份用户指南中文版是基于spru523的英文原版翻译,并经过了校对和修正,旨在帮助不熟悉英文的开发者更好地理解和使用NDK。 1. **NDK简介** NDK 是一个集成的开发环境,它包含了构建网络应用程序所需的各种组件,如...

    Android NDK 一

    - **ndk-stack**:堆栈跟踪工具。 #### 四、使用 NDK 进行开发 - **基本流程**: 1. 创建一个新的 Android 项目。 2. 在项目中设置 NDK 的路径。 3. 编写 C/C++ 代码,并使用 JNI 与 Java 代码交互。 4. 使用...

    Android NDK *** could not be resolved

    如果文档中没有明确的解答,可以尝试搜索相关论坛如Stack Overflow或官方文档,寻找其他开发者遇到相同问题时的解决方案。 总之,解决"Android NDK *** could not be resolved"的问题,通常需要检查NDK的配置、项目...

    stack工具用于分析tombstone文件

    参考 http://blog.csdn.net/koffuxu/article/details/37959071

Global site tag (gtag.js) - Google Analytics