Java程序調試技巧淺析
用Java這么久,說來慚愧,大部分情況下使用的調試語句是:System.out.println("value:"+value);這種形式,這兩天看了些關于Java程序調試技巧的東西,總結一下,以后要積極使用:
一:一種很簡單的方法就是使用一個boolean量如:debugMode,需要看看程序的輸出時可以使用:if(debugMode)System.out.println("..");
在項目完畢后把debugMode變量設為false;這種方法的不足是:為了啟動或者禁止debug,必須改動代碼
二:一個比上述方法稍好的是:使用Java -D:如:Java -Ddebug=true MyClass,在使用這種方法時,必須在你所有的class中添加System.getProperty("debug")來取得調試標志,這樣***種方法的使用,就改為:
- public static final boolean debug;
- static{
- String sDebug=System.getProperty("debug");
- if(sDebug!=null && sDebug.equalsIngnoreCase("true"))
- debug=true;
- else
- debug = false;
- }
這樣在不更改source code的情況下可以直接修改Java程序調試標志,但是這樣不夠靈活,比如你不能指定哪一部分使用調試功能,而只是要使用調試功能就必須在代碼的全部使用,這樣就引出了第三種調試方法,可以定義一個用于調試的類。
- public class DebugManager {
- public static final String SYSTEM_DEBUG_KEY="system.Debug";
- public static final boolean debug;
- static {
- debug = toBoolean(SYSTEM_DEBUG_KEY);
- }
- private static boolean toBoolean(String key){
- boolean debug;
- String sDebug = System.getProperty(key);
- if(sDebug != null && sDebug.equalsIgnoreCase("true"))
- debug = true;
- else
- debug =false;
- return debug;
- }
- public static boolean getSystemDebug(){
- return debug;
- }
- public static boolean getSystemDebug(String applicationKey) {
- if(debug || toBoolean(applicationKey))
- return true;
- else
- return false;
- }
- }
這樣對于一個application(Test)可以著牙功能調用:
boolean debug =DebugManager.getSystemDebug(applicationKey);
要打開Test的調試功能,只需:
java -DTest.Debug=true Test
當然這個類可以進行進一步擴展,比如將其變?yōu)槿罩竟芾恚刂普{試信息的輸出位置等
三、使用斷言
斷言是Merlin(jdk1.4)中一項新功能,默認情況下不使用斷言,但是programmer可以在任何時候enable或者disable這項功能,從而可以在測試時啟用斷言驗證,而在部署時禁用斷言驗證,而程序運行時若用戶碰到問題時再重新啟用斷言。斷言檢查,失敗時不會拋出
Exception,而是拋出AssertionError,
1,斷言的兩種語法形式:
(1)assert booleanExpression;
(2) assert boolExpression:message; //message將作為錯誤拋出后的結果顯示
assert必須位AssertTest于可執(zhí)行快中,不能將assert和實例的類變量一起使用,但可以將其放在任何方法內。
2,在Java程序調試中啟用斷言:
編譯:javac -source 1.4 AssertTest.java
運行:java -ea AssertTest (參數)
-ea是啟用斷言的簡易方法,但是-ea不能用于系統(tǒng)類,
(1)若要對系統(tǒng)類使用斷言:則需:-enablesystemassertions,或者-esa
(2)若要對這個package啟用斷言:要在-ea后加(:,package的名字,...)如對test.util包及其所有的子包啟用斷言,則可以java -ea:test.util... AssertTest
【編輯推薦】