Android C++层打印函数调用栈

时间:2024-05-22 18:19:01

1、添加头文件:

#include <utils/CallStack.h>

2、在需要打印函数调用栈的函数中添加如下代码:

 CallStack stack;
 stack.update();
 stack.log("LPM_DEBUG");   //后面字符串表示log中的包含字符,在查找时会比较方便

3、在函数文件对应的Android.mk中:

LOCAL_SHARED_LIBRARIES := libutils \  这个一般都会有

                                                       libutilscallstack \   还需要加上这个坑爹的玩意,否则编译不过

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

4、通过上面的代码之后,就会得到如下的打印

函数调用栈信息
Android C++层打印函数调用栈

 

 

 

 

 

5、如何确定updateRegion函数处在哪个目录下?

注意提示信息:0000cd45   、/vendor/lib/librtk_videorenderer.so ,去找到这个so所在的路径

找到并去到out/target/product/xxx/symbol/vendor/lib/hw 目录****意是在symbol目录,其他目录下的没有具体信息

6、使用addr2line

 addr2line -C -f -e librtk_videorenderer.so 0000cd45    就能看到具体的文件路径