Android 中调试手段 打印函数调用栈信息
来源:互联网 发布:卖家如何申请淘宝介入 编辑:程序博客网 时间:2024/05/29 13:51
下面来简单介绍下 android 中的一种调试方法。
在 android 的 app 开发与调试中,经常需要用到打 Log 的方式来查看函数调用点。
这里介绍一种方法来打印当前栈中的函数调用关系
StackTraceElement[] ste = new Throwable().getStackTrace(); if(ste.length >=1) { for(int i = 1; i < ste.length; i++) { Log.d(TAG, "File:" + ste[i].getFileName() + ", Line: " + ste[i].getLineNumber() + ", MethodName:" + ste[i].getMethodName()); } }
这里我将上述代码块放在 LabelDisplayItem 类的 updateContent 函数中,打印出来的 Log 如下所示
D/AlbumSetDir( 1554): File:AlbumSetSlidingWindow.java Line: 550 MethodName:render
D/AlbumSetDir( 1554): File:SlotView.java Line: 375 MethodName:renderItem
D/AlbumSetDir( 1554): File:SlotView.java Line: 304 MethodName:render
D/AlbumSetDir( 1554): File:AlbumSetView.java Line: 203 MethodName:render
D/AlbumSetDir( 1554): File:GLView.java Line: 244 MethodName:renderChild
D/AlbumSetDir( 1554): File:GLView.java Line: 218 MethodName:render
D/AlbumSetDir( 1554): File:AlbumSetPage.java Line: 175 MethodName:render
D/AlbumSetDir( 1554): File:GLRootView.java Line: 305 MethodName:onDrawFrameLocked
D/AlbumSetDir( 1554): File:GLRootView.java Line: 266 MethodName:onDrawFrame
D/AlbumSetDir( 1554): File:GLSurfaceView.java Line: 1468 MethodName:guardedRun
D/AlbumSetDir( 1554): File:GLSurfaceView.java Line: 1222 MethodName:run
注意,这是栈,调用关系是从下往上看的
如果只是想在文件中添加一些输出,譬如想输出当前哪一行,在哪个文件中,用下面的测试代码就可以了
public class Test { public static void main(String args[]) { System.out.println("This is " + getLineInfo()); } public static String getLineInfo() { StackTraceElement ste = new Throwable().getStackTrace()[1]; return ste.getFileName() + ": Line " + ste.getLineNumber(); } }
有兴趣的朋友可以尝试一下。
看到有更简单的打印函数调用栈的方法:Log.d(TAG,Log.getStackTraceString(new Throwable()));
更多内容可以参考:http://blog.csdn.net/freshui/article/details/9456889
- Android 中调试手段 打印函数调用栈信息
- Android下打印函数调用栈信息
- Linux驱动调试手段:打印信息日志
- MFC 如何调用打印调试信息函数
- 打印函数调用栈信息
- android中打印函数调用栈
- Android 打印函数调用堆栈调试
- Android Jni中打印调试信息
- android调试:代码中打印内存信息
- Android.mk 中打印调试信息
- Android打印函数调用栈
- Android的调用栈信息打印
- android中打印函数调用栈、内存使用、屏幕分辨率
- android中打印函数调用栈、内存使用、屏幕分辨率
- android中打印函数调用栈、内存使用、屏幕分辨率
- Netbean Android 打印调试信息
- Android中打印调用栈
- Android底层库打印调试信息到logcat中查看
- 语言的歧义
- 给孩子下载电子书的注意事项
- 获取Html元素在页面中的绝对位置及问题
- [andriod]四大组件之Service
- 函数模块:CTVB_COMPARE_TABLES
- Android 中调试手段 打印函数调用栈信息
- css点井区别
- CronTriggers 按日程来触发任务
- 原文:100个经典的C算法
- 粗谈pcap_next_ex()
- O2O分享5:O2O的社会化营销(上)
- IO_REMOVE_LOCK使用方法小结
- android Camera 旋转 90 °问题
- linux/mm.memory.c/copy_page_tables