下面来简单介绍下 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.javaLine: 550MethodName:render
D/AlbumSetDir( 1554): File:SlotView.java Line: 375MethodName:renderItem
D/AlbumSetDir( 1554): File:SlotView.java Line: 304MethodName:render
D/AlbumSetDir( 1554): File:AlbumSetView.java Line: 203 MethodName:render
D/AlbumSetDir( 1554): File:GLView.java Line: 244MethodName:renderChild
D/AlbumSetDir( 1554): File:GLView.java Line: 218MethodName:render
D/AlbumSetDir( 1554): File:AlbumSetPage.java Line: 175 MethodName:render
D/AlbumSetDir( 1554): File:GLRootView.java Line: 305MethodName:onDrawFrameLocked
D/AlbumSetDir( 1554): File:GLRootView.java Line: 266MethodName: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

更多相关文章

  1. 箭头函数的基础使用
  2. Python技巧匿名函数、回调函数和高阶函数
  3. Android中startService的使用及Service生命周期
  4. Android中间键开发
  5. 2011.06.07(2)——— android 调试android源码包下的package应用的
  6. aidl
  7. Android(安卓)IOS WebRTC 音视频开发总结(六)-- iOSIntroduce
  8. Android更新UI的方法
  9. Android(安卓)四大组件 —— 活动(使用Intent 实现活动的显示跳转

随机推荐

  1. Android binder -serviceManager
  2. Android之条码扫描二维码扫描
  3. Android学习笔记之数据库
  4. Android动画之view动画
  5. Android动画TweenAnimation的使用方法
  6. windows下Appium安装教程
  7. 第三部分 优秀项目
  8. android设备调用usb外置摄像头方法及案例
  9. 如何使Android应用程序获取系统权限 来修
  10. Android 进行单元测试