麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > .NET > 正文

Dot Net的調試 - 1

2024-07-21 02:19:52
字體:
來源:轉載
供稿:網友
debug是整個軟件開發過程中最痛苦的部分之一。我們不想說發現一個小bug是多么的困難-你可能已經都知道。軟件中bug的數量是隨著軟件的復雜程度和經常沒有及時修正bug而增長的。這些bug和軟件的負責程度互相影響,使工程變得更加復雜。所以我們不斷的監控和修改bug。

最好的辦法是執行單元測試的時候來修正bug,當軟件出現問題的時候,軟件不會告訴我們哪里出現錯誤,為什么出現錯誤,我們的任務就是跟蹤進程去解決他們。

這篇文章我們就是想告訴你怎樣利用dotnet framework來調試和跟蹤讓這個處理過程變得簡單。我們將簡要的告訴你怎么樣有效的使用他們,并用結合例子說明。

跟蹤

在這篇文章中首先要討論的調試的策略是跟蹤。跟蹤是很強大的技術,因為他允許你看到應用程序的整個在運行期的整個行為,分析他是最有效的,盡管他不能提供需要的信息。

dotnet在system.diagnostics名字空間中提供了跟蹤的功能,正確的說是trace class

trace是個靜態類(這意味著所有的成員是靜態的,你不需要初始化他來獲得它的功能)

.產生一個斷言(有條件或沒有)

.根據提供的條件輸出跟蹤信息

.格式化跟蹤輸出信息

讓我們從簡要的成員方法開始研究:

public static void assert(bool)

public static void assert(bool,string)

public static void assert(bool,string,string)



assert方法顯示一個失敗信息(應用程序失敗的時候顯示信息,允許用戶中斷執行,忽略錯誤或者重新運行引起錯誤的代碼),如果條件是false,兩個重載函數允許顯示指定的自定義一個或兩個跟著的信息。(這些信息通過string參數設置,這么做允許開發者顯示額外的斷言失敗的信息)

//asertion demo

//

//purpose: to demonstrate results of different assert method calls

using system;

using system.diagnostics

namespace assertion

{

class application

{

[stathread]

static void main(string[] args)

{

//simple assertion. no additional message

trace.assert(false);

}

}

}

程序將顯示下面的消息對話框




正如你看到的,僅僅是顯示異常信息。沒有顯示任何上下文信息,所以我們不能看到失敗的原因。下面,應用程序調用assert方法用它的一個屬性:

//asertion demo

//

//purpose: to demonstrate results of different assert method calls

using system;

using system.diagnostics

namespace assertion

{

class application

{

[stathread]

static void main(string[] args)

{

//simple assertion. no additional message

trace.assert(false,”simple assertion message”);

}

}

}

這個程序顯示了一個更多信息的對話框。可以看到我們能提供的關于失敗原因的信息。


調用有兩個信息的assert方法,組成更加詳細的斷言:

//asertion demo

//

//purpose: to demonstrate results of different assert method calls

using system;

using system.diagnostics

namespace assertion

{

class application

{

[stathread]

static void main(string[] args)

{

//simple assertion. no additional message

trace.assert(false,”simple assertion message”,”this message just an example.in real application you can provite detailed information here’);

}

}

}

你現在看到更加詳細的信息:


事實上,當檢查重要條件,比如數據正確性等情況的時候才用這種方法。下邊是他最常用的例子:public void storeobject(persistentobject obj)

{

trace.assert(obj != null, "cannot store null object");

}

這個方法檢查object對象不是null的時候被存儲。當程序失敗的時候是產生異常的最好時間,但這不是必要條件。例如,如果這個方法保存了一些重要的程序數據,斷言是完美的選擇。

備注:調試跟蹤是有用的,如果最終發行版本中包含了斷言信息對用戶來說是無法忍受的。下面的竅門可以幫助你控制跟蹤開關。



如果你手工編譯工程(比如命令行編譯),缺省顯示跟蹤信息。如果在c#中用跟蹤功能,當你編譯代碼的時候,要加/d:trace標志來編譯命令行,或者你可以簡單的加入#define trace到文件最頂端。

比如,下面的小程序:

using system;

using system.diagnostics;

namespace traceshow

{

class calss1

{

///<summary>

///the main entry point for the application

///</summary>

[stathread]

static void main(string[] args)

{

trace.listeners.add(new textwritertracelister(console.out));

trace.write(“hey,this is a trace message/n”, “simple message”);

}

}

}

如果在命令行編譯,你將看不到任何信息,除非你加上/d:trace或者加入#define trace到文件頂部。

當你在visual c#中編譯程序這種情形將改變,visual c#中默認是可用的,結論是你將看到跟蹤信息。關閉調試功能,瀏覽工程屬性(可以在解決方案瀏覽器重或者view->property菜單項。在這個屬性頁面對話框中,發現條件編譯常量(在configuration properties文件夾下,build pane中這個選項是鎖定狀態),去掉trace選項):


public static void fail(string)

public static void fail(string, string)

fail方法產生一個無條件斷言。它的有些行為有點像assert方法,但是他不需要任何處理條件。

帶有簡單條件的失敗條件不能被選中那么用這個方法。下邊的例子是這種異常的處理情形:

try

{

throw new exception(“sample exception”);

}

catch(exception ex)

{

trace.fail(“exception caught”, ex.message);

}



pubic static void write(object)

public static void write(string)

public static void write(object, string)

public static void write(string,string)



trace類可以在不產生任何條件的情況下寫入跟蹤信息。比如信息輸出到作為跟蹤信息的接收者的設備中。用write方法執行輸出。

write方法可以建立作為對象或者字符串的描繪信息。以前的案例中,object.tostring被呼叫執行。有其他三個方法可以執行類似的行為:writeline輸出行,writeif-條件信息,writelineif輸出一行條件信息。

write方法的第二個參數指定將要寫入信息前的分類(比如 一個字符串)

輸出被注冊為偵聽器。偵聽器是可以輸出跟蹤信息到一些設備的對象。注意assert和fail方法經常輸出錯誤信息到窗體或者控制臺,不管那個偵聽器被選中。這類對象必須繼承tracelistener類,他有以下重要的方法:

public virtual void fail(string)

public virtual void fail(string,string)



public virtual void flush(string)



public virtual void write(object)

public abstract void write(string)

public virtual void write(object,string)

public virtual void write(string,string)



public virtual void writeline(object)

public virtual void writeline(string)

public virtual void writeline(object,string)

public virtual void writeline(string,string)


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美精品一区二区三区四区 | 精品一区二区久久久久久按摩 | 欧美激情猛片xxxⅹ大3 | 美女污污视频在线观看 | 国产一区二区在线免费 | www.com超碰| 免费的性生活视频 | 巨根插入 | 日韩黄网站 | 欧美一级网 | 欧洲精品久久久久69精品 | 美女黄页网站免费进入 | 在线成人免费观看 | 国产精品视频二区不卡 | 午夜偷拍视频 | 久草在线资源福利站 | 国产精品美女久久久久久不卡 | 久草导航 | 福利免费在线观看 | 182tv成人福利视频免费看 | 日本在线播放一区二区三区 | 成人毛片100部免费观看 | 国产亚洲精品久久 | 免费看日韩片 | 国产精品久久久久久久亚洲按摩 | 精品久久久久久久久中文字幕 | 在线播放黄色网址 | 色中色在线播放 | 久久人添人人爽人人爽人人片av | 亚洲精品在线观看免费 | av免费提供| chengrenzaixian | 女人叉开腿让男人桶 | 69性欧美高清影院 | 毛片电影在线看 | 国产亚洲在 | 欧美成人免费一区二区三区 | 国产妇女乱码一区二区三区 | 一本色道久久综合亚洲精品图片 | 亚洲精品成人18久久久久 | 久久精品一区二区三区国产主播 |