Android小技巧(三):調試程序執行流程的小技巧

轉載自:http://blog.csdn.net/mylzc/article/details/6827230html

介紹:在開發的過程當中咱們常常須要調試程序的執行路徑,如咱們想知道一個Activity的生命週期方法的調用順序,咱們可能會寫以下代碼:java

[html] view plain copy
  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. ...  


這樣每次都要輸入兩個參數,有沒有更簡便的方法呢?android

咱們能夠經過Thread.currentThread().getStackTrace()獲取當前堆棧調用信息,從堆棧信息中能夠獲取當前調用的java文件名,類名,方法名和代碼行號。app

因而,咱們封裝了一個工具類LogHelper。咱們只須要使用這個工具類,在跟蹤的位置調用LogHelper.trace()方法就能夠打印當前調用方法的信息。ide

例子:打印Activity的生命週期方法執行流程。工具

LogHelper.java性能

[java] view plain copy
  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.javaspa

[java] view plain copy
  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打印結果:.net

總結:調試

經過使用LogHelper的trace()方法,在調試的時候咱們能夠很是方便地打印應用的執行流程。

相關文章
相關標籤/搜索