sunwengang blog

在Android源码调试函数的堆栈

字数统计: 139阅读时长: 1 min
2019/07/16 Share

在Android代码中可以通过了解函数的CallStack加速调试和分析过程,本文说明如何在Android运行时加入CallStack及Android P上的注意点。

Java

1
2
import android.util.Log; 
Log.d("yourTag", Log.getStackTraceString(new Exception()));

C++

Android 9以前CallStack call是被build进libutils, framework大部分service都是link了该lib,因此可以直接使用Callstack。
Android 9开始后CallStack被build进libutilscallstack,因此直接使用Callstack会报undefined reference to ‘android::CallStack::CallStack 在Android.bp或Android.mk中加入”libutilscallstack” 即可.

1
2
3
4
5
6
7
8
9
10
#include <utils/CallStack.h>

ALOGD("dump callstack");
android::CallStack stack;
stack.update();
stack.dump("yourTag");
// stack.log("yourTag"); //callstack LOG_TAG

Methods:
adb logcat | grep yourTag
CATALOG
  1. 1. Java
  2. 2. C++