调试程序执行流程的小技巧

简介:

介绍:在开发的过程中我们经常需要调试程序的执行路径,如我们想知道一个Activity的生命周期方法的调用顺序,我们可能会写如下代码:

  1. .....  
  2. public void onResume() {  
  3.     super.onResume();  
  4.     Log.d("Tag","onResume()");  
  5. }  
  6.   
  7. public void onStart() {  
  8.     super.onStart();  
  9.     Log.d("Tag","onStart()");  
  10. }  
  11.   
  12. public void onPause() {  
  13.     super.onPause();  
  14.     Log.d("Tag","onPause()");  
  15. }  
  16.   
  17. public void onStop() {  
  18.     super.onStop();  
  19.     Log.d("Tag","onStop()");  
  20. }  
  21.   
  22. ...  

这样每次都要输入两个参数,有没有更简便的方法呢?

我们可以通过Thread.currentThread().getStackTrace()获取当前堆栈调用信息,从堆栈信息中可以获取当前调用的java文件名,类名,方法名和代码行号。

于是,我们封装了一个工具类LogHelper。我们只需要使用这个工具类,在跟踪的位置调用LogHelper.trace()方法就可以打印当前调用方法的信息。

例子:打印Activity的生命周期方法执行流程。

LogHelper.java

  1. package com.zhuozhuo;  
  2.   
  3. import android.util.Log;  
  4.   
  5. public final class LogHelper {  
  6.     private static boolean mIsDebugMode = true;//获取堆栈信息会影响性能,发布应用时记得关闭DebugMode  
  7.     private static String mLogTag = "LogHelper";  
  8.   
  9.     private static final String CLASS_METHOD_LINE_FORMAT = "%s.%s()  Line:%d  (%s)";  
  10.   
  11.     public static void trace() {  
  12.         if (mIsDebugMode) {  
  13.             StackTraceElement traceElement = Thread.currentThread()  
  14.                     .getStackTrace()[3];//从堆栈信息中获取当前被调用的方法信息  
  15.             String logText = String.format(CLASS_METHOD_LINE_FORMAT,  
  16.                     traceElement.getClassName(), traceElement.getMethodName(),  
  17.                     traceElement.getLineNumber(), traceElement.getFileName());  
  18.             Log.d(mLogTag, logText);//打印Log  
  19.         }  
  20.     }  
  21. }  
LogHelperActivity.java
  1. package com.zhuozhuo;  
  2.   
  3. import android.app.Activity;  
  4. import android.os.Bundle;  
  5. import android.util.Log;  
  6.   
  7. public class LogHelperActivity extends Activity {  
  8.     /** Called when the activity is first created. */  
  9.       
  10.       
  11.     @Override  
  12.     public void onCreate(Bundle savedInstanceState) {  
  13.         super.onCreate(savedInstanceState);  
  14.         setContentView(R.layout.main);  
  15.         LogHelper.trace();  
  16.     }  
  17.       
  18.       
  19.     @Override  
  20.     public void onStart() {  
  21.         super.onStart();  
  22.         LogHelper.trace();  
  23.     }  
  24.       
  25.     @Override  
  26.     public void onResume() {  
  27.         super.onResume();  
  28.         LogHelper.trace();  
  29.     }  
  30.       
  31.     @Override  
  32.     public void onPause() {  
  33.         super.onPause();  
  34.         LogHelper.trace();  
  35.     }  
  36.       
  37.     @Override  
  38.     public void onStop() {  
  39.         super.onStop();  
  40.         LogHelper.trace();  
  41.     }  
  42.       
  43.     @Override  
  44.     public void onDestroy() {  
  45.         super.onDestroy();  
  46.         LogHelper.trace();  
  47.     }  
  48. }  

Log打印结果:

总结:

通过使用LogHelper的trace()方法,在调试的时候我们可以非常方便地打印应用的执行流程。
目录
相关文章
|
7月前
|
Windows
调试实战——使用windbg调试TerminateThread导致的死锁
本文记录了调试 TerminateThread 导致的死锁问题
|
3月前
|
NoSQL Shell C语言
GDB调试学习(一):单步执行和跟踪函数调用
GDB调试学习(一):单步执行和跟踪函数调用
42 1
|
编译器 C语言
C程序调试过程常见的错误
在C语言编程,一般需要借助C相关的编译软件,例如,在Keil uVision5编程环境下,如果提示工具连接错误,则表示MDK安装程序有问题,重新卸载,并全部删除后重新再进行安装后即可。
|
C++
C++程序调试详解(包括打断点 单步调试 数据断点...)
C++程序调试详解(包括打断点 单步调试 数据断点...)
257 0
C++程序调试详解(包括打断点 单步调试 数据断点...)
|
iOS开发
Xcode断点 中断不正常 每次断点都进入汇编
Xcode断点 中断不正常 每次断点都进入汇编
270 0
|
PHP
什么?你还不会断点调试代码(2)
什么?你还不会断点调试代码
85 0
什么?你还不会断点调试代码(2)
|
PHP
什么?你还不会断点调试代码
什么?你还不会断点调试代码
90 0
什么?你还不会断点调试代码
|
Java 程序员 Android开发
熟练使用IDEA的断点调试(Breakpoint),大大提升你调试代码的效率(行断点、属性断点、异常断点、条件断点、远程debug...)【享学Java】(上)
熟练使用IDEA的断点调试(Breakpoint),大大提升你调试代码的效率(行断点、属性断点、异常断点、条件断点、远程debug...)【享学Java】(上)
熟练使用IDEA的断点调试(Breakpoint),大大提升你调试代码的效率(行断点、属性断点、异常断点、条件断点、远程debug...)【享学Java】(上)
|
安全 IDE Java
熟练使用IDEA的断点调试(Breakpoint),大大提升你调试代码的效率(行断点、属性断点、异常断点、条件断点、远程debug...)【享学Java】(下)
熟练使用IDEA的断点调试(Breakpoint),大大提升你调试代码的效率(行断点、属性断点、异常断点、条件断点、远程debug...)【享学Java】(下)
熟练使用IDEA的断点调试(Breakpoint),大大提升你调试代码的效率(行断点、属性断点、异常断点、条件断点、远程debug...)【享学Java】(下)
|
NoSQL Python Windows
开源代码分析技巧之二——gdb单步调试
在海量的源码面前,如何更好的切入到源码,锁定我们需要的那一行,有时显得格外重要。
226 0