System.Diagnostics.Debug和System.Diagnostics.Trace


在 .net 類庫中有一個 system.diagnostics 命名空間,該命名空間提供了一些與系統進程、事件日志、和性能計數器進行交互的類庫。當中包括了兩個對開發人員而言十分有用的類——debug類和trace類。本文介紹了這兩個類的一些基本用途,旨在提高廣大開發人員的開發效率。 
使用debug類來幫助調試 

調試程序對每個程序員來說是家常便飯。可是我們會經常遇到一些情況讓我們頭疼,例如: 

當我們在開發一個界面控件的時候,簡單的設斷點會增加paint事件的響應次數,而造成的環境參數改變。 
斷點設多了,程序常常停在正常運行的地方;這樣一來,調試一個錯誤要花費大量時間去尋找錯誤。 
這時,我們就需要利用system.diagnostics.debug類來幫助我們調試。我們可以通過調用debug.writeline(string message)函數,將我們所關心的信息打印在visual studio ide的output窗口中。也可以利用debug.assert(bool condition)來讓程序停在錯誤的地方,並且顯示call stack。 

debug類中所有函數的調用都不會在release版本里有效。也就是說,我們通過這種方法所加的代碼可以僅用於調試;在發布的時候無需刪任何代碼,就可以給用戶一個沒有調試指令的程序了。 



下面的這個例子演示了這兩個函數來幫助調試的方法: 

1、 新建一個visual studio c# project,采用默認的項目名。 

2、 往form1上拖一個label,並采用其缺省id。 

3、 在form1.cs中的form1類中添加下面的函數代碼: 

private int time=0; 
protected override void onpaint(painteventargs e) 

time++; 
this.label1.text="onpain called "+time.tostring()+" times."; 


protected override void onresize(eventargs e) 

system.diagnostics.debug.assert(this.width>200,"width should be larger than 200."); 
system.diagnostics.debug.writeline(size.tostring()); 


4、 編譯並運行項目的debug版本。 

5、 切換visual studio .net ide到output窗口。 

6、切換到剛才的程序,改變主窗口的大小,您可以在ide中看到form1窗口的實時大小,並在form1上看到onpaint被調用的次數。當窗口的寬度小於等於200個像素的時候,系統會彈出一個assertion fail的對話框。里面顯示了當前程序的call stack。如果您在onpaint中設置了斷點,想要調試程序的話,那么您會進入一個死循環,直到您停止調試。 

debug類和trace類的區別 

您一定發現了在system.diagnostics命名空間中還有一個名為trace的類。它的函數功能和debug非常相似。為什么要有這樣兩個功能類似的類呢? 

原因是這樣的,debug類里所提供的函數僅在編譯時帶#debug宏參數才奏效,一旦到了release版本中,這些函數都會被忽略。也就是說debug類的功能僅在程序員開發的時候能用。而trace則不同,它能在release版本的程序中也被運行,這樣程序員就可以在release版本的程序中添加一些debug類提供的功能了。 

使用trace類來做程序日志 

接下來的問題就是:我們程序員能利用trace類的功能做些什么呢?我們可以用它來做程序的日志。 

1、 打開剛剛的project。 

2、 用下面的代碼覆蓋剛才第2步的代碼: 

private void calculate() 

int a=1,b=1; 
try 

system.random r = new random(); 
while (true) 

a=(int)(r.nextdouble()*10); 
b=(int)(r.nextdouble()*10); 
system.diagnostics.trace.writeline(system.datetime.now.tostring()+": "+ 
a.tostring()+"/"+b.tostring()+"="+(a/b).tostring()); 


catch (exception ex) 

system.diagnostics.trace.writeline(system.datetime.now.tostring()+": "+a.tostring()+ 
"/"+b.tostring()+"="+" error: "+ex.message); 
messagebox.show(ex.message); 



3、在構造函數form1()的最后添加下面的代碼,將trace的輸出重定向到app.log文件中: 

system.diagnostics.trace.listeners.clear(); 
system.diagnostics.trace.autoflush=true; 
system.diagnostics.trace.listeners.add(new system.diagnostics.textwritertracelistener("app.log")); 

4、拖一個按鈕到該form上,雙擊按鈕,在button1_click函數中添加如下代碼: 

calculate(); 
application.exit(); 

5、運行該程序的release版本,點擊添加的按鈕,程序便開始執行一位隨機數除法。由於是隨機數,可能會出現出數為0的情況,這樣程序就會拋出exception,這是程序會自動中止。 

6、在該程序所在的目錄里您可以發現出現了一個新的文件app.log,里面記錄了各個時刻的運算紀錄,並把exception紀錄在日志中。 

小結 

利用 system.diagnostics.debug 類和 system.diagnostics.trace 類可以幫助程序員方便地進行調試程序並檢測程序運行情況。 

debug類的所有調用僅在程序的debug版本中有效;而trace類的調用能在release版本和debug版本中都有效。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM