VS2010断点设置技巧
***************************************************
更多精彩,歡迎進(jìn)入:http://shop115376623.taobao.com
***************************************************
許多Visual Studio下的程序員,甚至一些很有經(jīng)驗(yàn)的開發(fā)人員,都不知道這些技巧。希望這篇文章能幫你掌握這些技巧。它們都很簡(jiǎn)單,卻能幫你節(jié)約大量的時(shí)間。
一、跳到當(dāng)前光標(biāo)處(Ctrl+F10)
我經(jīng)常看到人們?yōu)榱说竭_(dá)目標(biāo)代碼位置,而在程序中早早設(shè)定了斷點(diǎn),然后反復(fù)地按F10/F11,一步步走到目標(biāo)代碼處。當(dāng)程序員的確需要仔細(xì)觀察每一步的狀態(tài)變化時(shí), F10/F11是合理的選擇。然而多數(shù)情況下,人們只想快速到達(dá)他們真正關(guān)心的代碼處,這時(shí)候F10/F11就不是最佳選擇了。
這時(shí),你應(yīng)該利用“跳到當(dāng)前光標(biāo)處”這個(gè)功能。先把光標(biāo)定位在要測(cè)的目標(biāo)代碼行上,再同時(shí)按Ctrl和F10,被測(cè)程序?qū)⒅苯犹皆撔型O隆D阍僖膊挥冒丛S多次F10/F11了。即使目標(biāo)代碼位于獨(dú)立的類或方法中,你仍然可以從當(dāng)前正在檢查的地方跳過去。
二、條件中斷
另一種常見的情況是:開發(fā)人員設(shè)置斷點(diǎn),運(yùn)行程序,利用不同的輸入觸發(fā)斷點(diǎn),然后在斷點(diǎn)處手工檢查是否滿足某些特定的條件,從而決定是否繼續(xù)調(diào)查。如果當(dāng)前場(chǎng)景不是他們想要的,按F5繼續(xù)運(yùn)行程序,嘗試別的輸入,手動(dòng)重復(fù)剛才的過程。
針對(duì)上述情況,Visual Studio提供了一個(gè)方便得多的功能——“條件中斷”。只有當(dāng)程序滿足了開發(fā)人員預(yù)設(shè)的條件后,條件斷點(diǎn)才會(huì)被觸發(fā),調(diào)試器中斷。這將避免頻繁地手工檢查/恢復(fù)程序運(yùn)行,大量減少調(diào)試過程中的手工和煩瑣工作。
如何設(shè)置條件斷點(diǎn)
設(shè)置條件斷點(diǎn)非常容易。在特定的行上,按F9設(shè)置斷點(diǎn)。
然后右擊斷點(diǎn)–編輯窗口左側(cè)的紅點(diǎn),在上下文菜單上選擇“Condition…”。
這時(shí)彈出一個(gè)對(duì)話框供你設(shè)置激活該斷點(diǎn)所需的條件。比如:我們希望只有當(dāng)局部變量paginatedDinners的尺寸小于10時(shí),調(diào)試才中斷。我們可以寫出如下的表達(dá)式:
現(xiàn)在我再運(yùn)行這個(gè)程序,實(shí)現(xiàn)搜索,只有返回值小于10時(shí),程序運(yùn)行才會(huì)被中斷。對(duì)于大于10的值,該斷點(diǎn)將被跳過。
三、記錄到達(dá)斷點(diǎn)次數(shù)
有時(shí)你希望,只有當(dāng)?shù)贜次滿足條件的運(yùn)行到達(dá)斷點(diǎn)時(shí),才中斷程序運(yùn)行。例如:當(dāng)?shù)谖宕畏祷厣儆?0份晚餐的查詢結(jié)果時(shí),中斷程序運(yùn)行。
可以通過右擊斷點(diǎn),然后在彈出菜單上選擇“Hit count…”菜單命令實(shí)現(xiàn)。
這時(shí)系統(tǒng)彈出一個(gè)對(duì)話框,它允許你指定:(1)當(dāng)滿足條件,而且進(jìn)入斷點(diǎn)的累計(jì)次數(shù)等于N時(shí),斷點(diǎn)命中一次。(2)當(dāng)滿足條件,而且進(jìn)入斷點(diǎn)的累計(jì)次數(shù)是N的倍數(shù)時(shí),斷點(diǎn)命中一次。(3)當(dāng)滿足條件,而且進(jìn)入斷點(diǎn)的累計(jì)次數(shù)大于N時(shí),每次命中斷點(diǎn)。
四、機(jī)器/線程/進(jìn)程過濾
設(shè)置如下:右擊斷點(diǎn);在彈出菜單上選擇“Filter…”菜單命令;然后指定命中斷點(diǎn)的特定條件:在指定的機(jī)器上、或指定的進(jìn)程中、或指定的線程中。
跟蹤點(diǎn)—進(jìn)入斷點(diǎn)時(shí)的自定義操作
許多人不知道“跟蹤點(diǎn)(TrackPoints)”這個(gè)調(diào)試功能。“跟蹤點(diǎn)“是種特殊的斷點(diǎn),當(dāng)它被命中時(shí),它會(huì)觸發(fā)一系列自定義操作。如果你想觀察程序的行為,而又不想中斷調(diào)試的時(shí)候,這個(gè)功能尤其有用。
我將用一個(gè)簡(jiǎn)單的控制臺(tái)程序來演示如何使用“跟蹤點(diǎn)”。如下是Fibonacci數(shù)列的一個(gè)遞歸實(shí)現(xiàn):
以上程序中,我們使用Console.WriteLine() 輸出針對(duì)特定輸入值生成的最終斐波那契數(shù)列。如果希望在調(diào)試器里觀察操作中每一次遞歸運(yùn)算后的數(shù)列而又不實(shí)際中斷程序運(yùn)行,該怎么辦呢?“跟蹤點(diǎn)”可以輕松實(shí)現(xiàn)。
設(shè)置跟蹤點(diǎn)
你可以在特定的行上,按F9加跟蹤點(diǎn)。然后
右擊斷點(diǎn),在上下文菜單中選擇“When Hit…”:
在彈出對(duì)話框上,你可以設(shè)置命中該斷點(diǎn)時(shí),所觸發(fā)的事件。
在上面例子中,我們?cè)O(shè)定一旦命中斷點(diǎn)時(shí)就打印追蹤信息。注意,我們已經(jīng)把局部變量“x”的值,作為追蹤信息的一部分輸出。局部變量可以通過{變量名}語(yǔ)法輸出。你還可以利用系統(tǒng)內(nèi)置的命令($CALLER, $CALLSTACK, $FUNCTION等等),在追蹤信息中輸出常用的調(diào)試值。
在上例中,我們同時(shí)選中了底端的“continue execution“選項(xiàng),這說明我們不希望程序中斷調(diào)試狀態(tài),而是繼續(xù)運(yùn)行。唯一的不同是:每次斷點(diǎn)條件滿足時(shí),我們的自定義追蹤信息都將被輸出。
現(xiàn)在當(dāng)我們運(yùn)行程序時(shí),會(huì)發(fā)現(xiàn)自定義追蹤信息自動(dòng)顯示在Visual Studio的“輸出“窗口里。這讓我們很容易看到程序的遞歸調(diào)用過程:
你也可以選擇往應(yīng)用程序中添加一個(gè)自定義追蹤信息的監(jiān)聽器。這時(shí)追蹤點(diǎn)的輸出信息將通過它輸出,而不是Visual Studio的“輸出“窗口。
五、跟蹤點(diǎn)—運(yùn)行自定義的宏
當(dāng)命中跟蹤點(diǎn)時(shí),能否自動(dòng)輸出所有的局部變量?
Visual Studio中并沒有這樣的內(nèi)置功能,但我們可以寫一個(gè)自定義宏來實(shí)現(xiàn),然后在命中跟蹤點(diǎn)時(shí)調(diào)用該宏。這個(gè)的實(shí)現(xiàn)需要先打開Visual Studio的宏編輯器(工具->宏->宏IDE菜單命令),然后在項(xiàng)目資源管理器的MyMacros節(jié)點(diǎn)下選擇一個(gè)模塊或創(chuàng)建新模塊(如:加個(gè)名為“UsefulThings”的模塊),再把下面的VB宏代碼貼到模塊中并保存。
Sub DumpLocals()
Dim outputWindow As EnvDTE.OutputWindow
outputWindow = DTE.Windows.Item(EnvDTE.Constants.vsWindowKindOutput).Object
Dim currentStackFrame As EnvDTE.StackFrame
currentStackFrame = DTE.Debugger.CurrentStackFrame
outputWindow.ActivePane.OutputString(“*Dumping Local Variables*” + vbCrLf)
For Each exp As EnvDTE.Expression In currentStackFrame.Locals
outputWindow.ActivePane.OutputString(exp.Name + ” = ” + exp.Value.ToString() + vbCrLf)
Next
End Sub
上述宏代碼將循環(huán)當(dāng)前的堆棧,把所有的局部變量輸出到“輸出”窗口。
使用自定義的“DumpLocals”宏
然后,我們可以在如下的一個(gè)簡(jiǎn)單程序中使用剛定制的“DumpLocals”宏了:
上述代碼中,我們用F9在“Add”方法的返回值處加了個(gè)斷點(diǎn),然后右擊斷點(diǎn),在彈出菜單上選擇“When hit”。
將顯示如下對(duì)話框。和之前不一樣, 我們不選“Print a message”選項(xiàng),也不手工設(shè)定需要輸出的變量;而是選擇“Run a marco”復(fù)選框,并指定到我們上面創(chuàng)建的UsefulThings.DumpLocals宏上:
為了使程序能在命中跟蹤點(diǎn)后仍繼續(xù)運(yùn)行,我們將繼續(xù)選中“continue execution”復(fù)選框。
運(yùn)行程序
現(xiàn)在按F5運(yùn)行程序,當(dāng)“Add”方法被調(diào)用時(shí),我們會(huì)在Visual Studio的“輸出”窗口中看到如下結(jié)果。注意命中跟蹤點(diǎn)時(shí),宏會(huì)自動(dòng)列出每個(gè)局部變量的名稱和值:
總結(jié)
以上是生活随笔為你收集整理的VS2010断点设置技巧的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: OFD是什么?
- 下一篇: 写出float x 与“零值”比较的if