Android 中调试手段 打印函数调用栈信息

下面来简单介绍下 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

 

转自:http://blog.csdn.net/fulinwsuafcie/article/details/7601292

posted @   鸭子船长  阅读(3254)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示