VC調(diào)試以及TRACE()函數(shù)的用法

1.VC調(diào)試入門(mén)

1設(shè)置

為了調(diào)試一個(gè)程序傍药,首先必須使程序中包含調(diào)試信息。一般情況下玄帕,一個(gè)從AppWizard創(chuàng)建的工程中包含的Debug Configuration自動(dòng)包含調(diào)試信息,但是是不是Debug版本并不是程序包含調(diào)試信息的決定因素,程序設(shè)計(jì)者可以在任意的Configuration中增加調(diào)試信息绎巨,包括Release版本。

為了增加調(diào)試信息蠕啄,可以按照下述步驟進(jìn)行:

打開(kāi)Project settings對(duì)話(huà)框(可以通過(guò)快捷鍵ALT+F7打開(kāi)场勤,也可以通過(guò)IDE菜單Project/Settings打開(kāi))

選擇C/C++頁(yè),Category中選擇general 歼跟,則出現(xiàn)一個(gè)Debug Info下拉列表框和媳,可供選擇的調(diào)試信息 方式包括:

命令行Project settings說(shuō)明

無(wú)None沒(méi)有調(diào)試信息

/ZdLine Numbers Only目標(biāo)文件或者可執(zhí)行文件中只包含全局和導(dǎo)出符號(hào)以及代碼行信息,不包含符號(hào)調(diào)試信息

/Z7C 7.0- Compatible目標(biāo)文件或者可執(zhí)行文件中包含行號(hào)和所有符號(hào)調(diào)試信息哈街,包括變量名及類(lèi)型留瞳,函數(shù)及原型等

/ZiProgram Database創(chuàng)建一個(gè)程序庫(kù)(PDB),包括類(lèi)型信息和符號(hào)調(diào)試信息骚秦。

/ZIProgram Database for Edit and Continue除了前面/Zi的功能外撼港,這個(gè)選項(xiàng)允許對(duì)代碼進(jìn)行調(diào)試過(guò)程中的修改和繼續(xù)執(zhí)行坪它。這個(gè)選項(xiàng)同時(shí)使#pragma設(shè)置的優(yōu)化功能無(wú)效

選擇Link頁(yè),選中復(fù)選框"Generate Debug Info"帝牡,這個(gè)選項(xiàng)將使連接器把調(diào)試信息寫(xiě)進(jìn)可執(zhí)行文件和DLL

如果C/C++頁(yè)中設(shè)置了Program Database以上的選項(xiàng)往毡,則Link incrementally可以選擇。選中這個(gè)選項(xiàng)靶溜,將使程序可以在上一次編譯的基礎(chǔ)上被編譯(即增量編譯)开瞭,而不必每次都從頭開(kāi)始編譯。

設(shè)置

為了調(diào)試一個(gè)程序罩息,首先必須使程序中包含調(diào)試信息嗤详。一般情況下,一個(gè)從AppWizard創(chuàng)建的工程中包含的Debug Configuration自動(dòng)包含調(diào)試信息瓷炮,但是是不是Debug版本并不是程序包含調(diào)試信息的決定因素葱色,程序設(shè)計(jì)者可以在任意的Configuration中增加調(diào)試信息,包括Release版本娘香。

為了增加調(diào)試信息苍狰,可以按照下述步驟進(jìn)行:

打開(kāi)Project settings對(duì)話(huà)框(可以通過(guò)快捷鍵ALT+F7打開(kāi),也可以通過(guò)IDE菜單Project/Settings打開(kāi))

選擇C/C++頁(yè)烘绽,Category中選擇general 淋昭,則出現(xiàn)一個(gè)Debug Info下拉列表框,可供選擇的調(diào)試信息 方式包括:

命令行Project settings說(shuō)明

無(wú)None沒(méi)有調(diào)試信息

/ZdLine Numbers Only目標(biāo)文件或者可執(zhí)行文件中只包含全局和導(dǎo)出符號(hào)以及代碼行信息安接,不包含符號(hào)調(diào)試信息

/Z7C 7.0- Compatible目標(biāo)文件或者可執(zhí)行文件中包含行號(hào)和所有符號(hào)調(diào)試信息翔忽,包括變量名及類(lèi)型,函數(shù)及原型等

/ZiProgram Database創(chuàng)建一個(gè)程序庫(kù)(PDB)盏檐,包括類(lèi)型信息和符號(hào)調(diào)試信息歇式。

/ZIProgram Database for Edit and Continue除了前面/Zi的功能外,這個(gè)選項(xiàng)允許對(duì)代碼進(jìn)行調(diào)試過(guò)程中的修改和繼續(xù)執(zhí)行胡野。這個(gè)選項(xiàng)同時(shí)使#pragma設(shè)置的優(yōu)化功能無(wú)效

選擇Link頁(yè)贬丛,選中復(fù)選框"Generate Debug Info",這個(gè)選項(xiàng)將使連接器把調(diào)試信息寫(xiě)進(jìn)可執(zhí)行文件和DLL

如果C/C++頁(yè)中設(shè)置了Program Database以上的選項(xiàng)给涕,則Link incrementally可以選擇。選中這個(gè)選項(xiàng)额获,將使程序可以在上一次編譯的基礎(chǔ)上被編譯(即增量編譯)够庙,而不必每次都從頭開(kāi)始編譯。

2斷點(diǎn)

斷點(diǎn)是調(diào)試器設(shè)置的一個(gè)代碼位置抄邀。當(dāng)程序運(yùn)行到斷點(diǎn)時(shí)耘眨,程序中斷執(zhí)行,回到調(diào)試器境肾。斷點(diǎn)是 最常用的技巧剔难。調(diào)試時(shí)胆屿,只有設(shè)置了斷點(diǎn)并使程序回到調(diào)試器,才能對(duì)程序進(jìn)行在線(xiàn)調(diào)試偶宫。

設(shè)置斷點(diǎn):可以通過(guò)下述方法設(shè)置一個(gè)斷點(diǎn)非迹。首先把光標(biāo)移動(dòng)到需要設(shè)置斷點(diǎn)的代碼行上,然后

按F9快捷鍵

彈出Breakpoints對(duì)話(huà)框纯趋,方法是按快捷鍵CTRL+B或ALT+F9憎兽,或者通過(guò)菜單Edit/Breakpoints打開(kāi)。打開(kāi)后點(diǎn)擊Break at編輯框的右側(cè)的箭頭吵冒,選擇 合適的位置信息纯命。一般情況下,直接選擇line xxx就足夠了痹栖,如果想設(shè)置不是當(dāng)前位置的斷點(diǎn)亿汞,可以選擇Advanced,然后填寫(xiě)函數(shù)揪阿、行號(hào)和可執(zhí)行文件信息疗我。

去掉斷點(diǎn):把光標(biāo)移動(dòng)到給定斷點(diǎn)所在的行,再次按F9就可以取消斷點(diǎn)图甜。同前面所述碍粥,打開(kāi)Breakpoints對(duì)話(huà)框后,也可以按照界面提示去掉斷點(diǎn)黑毅。

條件斷點(diǎn):可以為斷點(diǎn)設(shè)置一個(gè)條件嚼摩,這樣的斷點(diǎn)稱(chēng)為條件斷點(diǎn)。對(duì)于新加的斷點(diǎn)矿瘦,可以單擊Conditions按鈕枕面,為斷點(diǎn)設(shè)置一個(gè)表達(dá)式。當(dāng)這個(gè)表達(dá)式發(fā)生改變時(shí)缚去,程序就 被中斷潮秘。底下設(shè)置包括“觀(guān)察數(shù)組或者結(jié)構(gòu)的元素個(gè)數(shù)”,似乎可以設(shè)置一個(gè)指針?biāo)赶虻膬?nèi)存區(qū)的大小易结,但是我設(shè)置一個(gè)比較的值但是改動(dòng) 范圍之外的內(nèi)存區(qū)似乎也導(dǎo)致斷點(diǎn)起效枕荞。最后一個(gè)設(shè)置可以讓程序先執(zhí)行多少次然后才到達(dá)斷點(diǎn)。

數(shù)據(jù)斷點(diǎn):數(shù)據(jù)斷點(diǎn)只能在Breakpoints對(duì)話(huà)框中設(shè)置搞动。選擇“Data”頁(yè)躏精,就顯示了設(shè)置數(shù)據(jù)斷點(diǎn)的對(duì)話(huà)框。在編輯框中輸入一個(gè)表達(dá)式鹦肿,當(dāng)這個(gè) 表達(dá)式的值發(fā)生變化時(shí)矗烛,數(shù)據(jù)斷點(diǎn)就到達(dá)。一般情況下箩溃,這個(gè)表達(dá)式應(yīng)該由運(yùn)算符和全局變量構(gòu)成瞭吃,例如:在編輯框中輸入 g_bFlag這個(gè)全局變量的名字碌嘀,那么當(dāng)程序中有g(shù)_bFlag= !g_bFlag時(shí)谍夭,程序就將停在這個(gè)語(yǔ)句處磷籍。

消息斷點(diǎn):VC也支持對(duì)Windows消息進(jìn)行截獲哀托。他有兩種方式進(jìn)行截獲:窗口消息處理函數(shù)和特定消息中斷卫键。

在Breakpoints對(duì)話(huà)框中選擇Messages頁(yè)荞彼,就可以設(shè)置消息斷點(diǎn)尽爆。如果在上面那個(gè)對(duì)話(huà)框中寫(xiě)入消息處理函數(shù)的名字谣旁,那么 每次消息被這個(gè)函數(shù)處理秦陋,斷點(diǎn)就到達(dá)(我覺(jué)得如果采用普通斷點(diǎn)在這個(gè)函數(shù)中截獲惠呼,效果應(yīng)該一樣)导俘。如果在底下的下拉 列表框選擇一個(gè)消息,則每次這種消息到達(dá)剔蹋,程序就中斷旅薄。

3Watch

VC支持查看變量、表達(dá)式和內(nèi)存的值泣崩。所有這些觀(guān)察都必須是在斷點(diǎn)中斷的情況下進(jìn)行少梁。

觀(guān)看變量的值最簡(jiǎn)單,當(dāng)斷點(diǎn)到達(dá)時(shí)矫付,把光標(biāo)移動(dòng)到這個(gè)變量上凯沪,停留一會(huì)就可以看到變量的值。

VC提供一種被成為Watch的機(jī)制來(lái)觀(guān)看變量和表達(dá)式的值买优。在斷點(diǎn)狀態(tài)下妨马,在變量上單擊右鍵,選擇Quick Watch杀赢, 就彈出一個(gè)對(duì)話(huà)框烘跺,顯示這個(gè)變量的值。

單擊Debug工具條上的Watch按鈕脂崔,就出現(xiàn)一個(gè)Watch視圖(Watch1,Watch2,Watch3,Watch4)滤淳,在該視圖中輸入變量或者表達(dá)式,就可以觀(guān)察 變量或者表達(dá)式的值砌左。注意:這個(gè)表達(dá)式不能有副作用脖咐,例如++運(yùn)算符絕對(duì)禁止用于這個(gè)表達(dá)式中,因?yàn)檫@個(gè)運(yùn)算符將修改變量的值汇歹,導(dǎo)致 軟件的邏輯被破壞屁擅。

4Memory

由于指針指向的數(shù)組,Watch只能顯示第一個(gè)元素的值秤朗。為了顯示數(shù)組的后續(xù)內(nèi)容,或者要顯示一片內(nèi)存的內(nèi)容笔喉,可以使用memory功能取视。在 Debug工具條上點(diǎn)memory按鈕硝皂,就彈出一個(gè)對(duì)話(huà)框,在其中輸入地址作谭,就可以顯示該地址指向的內(nèi)存的內(nèi)容稽物。

5Varibles

Debug工具條上的Varibles按鈕彈出一個(gè)框,顯示所有當(dāng)前執(zhí)行上下文中可見(jiàn)的變量的值折欠。特別是當(dāng)前指令涉及的變量贝或,以紅色顯示。

6寄存器

Debug工具條上的Reigsters按鈕彈出一個(gè)框锐秦,顯示當(dāng)前的所有寄存器的值咪奖。

7進(jìn)程控制

VC允許被中斷的程序繼續(xù)運(yùn)行、單步運(yùn)行和運(yùn)行到指定光標(biāo)處酱床,分別對(duì)應(yīng)快捷鍵F5羊赵、F10/F11和CTRL+F10。各個(gè)快捷鍵功能如下:

快捷鍵說(shuō)明

F5繼續(xù)運(yùn)行

F10單步扇谣,如果涉及到子函數(shù)昧捷,不進(jìn)入子函數(shù)內(nèi)部

F11單步,如果涉及到子函數(shù)罐寨,進(jìn)入子函數(shù)內(nèi)部

CTRL+F10運(yùn)行到當(dāng)前光標(biāo)處靡挥。

Call Stack

調(diào)用堆棧反映了當(dāng)前斷點(diǎn)處函數(shù)是被那些函數(shù)按照什么順序調(diào)用的。單擊Debug工具條上的Call stack就顯示Call Stack對(duì)話(huà)框鸯绿。在CallStack對(duì)話(huà)框中顯示了一個(gè)調(diào)用系列跋破,最上面的是當(dāng)前函數(shù),往下依次是調(diào)用函數(shù)的上級(jí)函數(shù)楞慈。單擊這些函數(shù)名可以跳到對(duì)應(yīng)的函數(shù)中去幔烛。

其他調(diào)試手段

系統(tǒng)提供一系列特殊的函數(shù)或者宏來(lái)處理Debug版本相關(guān)的信息,如下:

8宏名/函數(shù)名說(shuō)明

TRACE使用方法和printf完全一致囊蓝,他在output框中輸出調(diào)試信息

ASSERT它接收一個(gè)表達(dá)式饿悬,如果這個(gè)表達(dá)式為T(mén)RUE,則無(wú)動(dòng)作聚霜,否則中斷當(dāng)前程序執(zhí)行狡恬。對(duì)于系統(tǒng)中出現(xiàn)這個(gè)宏 導(dǎo)致的中斷,應(yīng)該認(rèn)為你的函數(shù)調(diào)用未能滿(mǎn)足系統(tǒng)的調(diào)用此函數(shù)的前提條件蝎宇。例如弟劲,對(duì)于一個(gè)還沒(méi)有創(chuàng)建的窗口調(diào)用SetWindowText等。

VERIFY和ASSERT功能類(lèi)似姥芥,所不同的是兔乞,在Release版本中,ASSERT不計(jì)算輸入的表達(dá)式的值,而VERIFY計(jì)算表達(dá)式的值庸追。


一個(gè)好的程序員不應(yīng)該把所有的判斷交給編譯器和調(diào)試器霍骄,應(yīng)該在程序中自己加以程序保護(hù)和錯(cuò)誤定位,具體措施包括:

對(duì)于所有有返回值的函數(shù)淡溯,都應(yīng)該檢查返回值读整,除非你確信這個(gè)函數(shù)調(diào)用絕對(duì)不會(huì)出錯(cuò),或者不關(guān)心它是否出錯(cuò)咱娶。

一些函數(shù)返回錯(cuò)誤米间,需要用其他函數(shù)獲得錯(cuò)誤的具體信息。例如accept返回INVALID_SOCKET表示accept失敗膘侮,為了查明 具體的失敗原因屈糊,應(yīng)該立刻用WSAGetLastError獲得錯(cuò)誤碼,并針對(duì)性的解決問(wèn)題喻喳。

有些函數(shù)通過(guò)異常機(jī)制拋出錯(cuò)誤另玖,應(yīng)該用TRY-CATCH語(yǔ)句來(lái)檢查錯(cuò)誤

程序員對(duì)于能處理的錯(cuò)誤,應(yīng)該自己在底層處理表伦,對(duì)于不能處理的谦去,應(yīng)該報(bào)告給用戶(hù)讓他們決定怎么處理。如果程序出了異常蹦哼, 卻不對(duì)返回值和其他機(jī)制返回的錯(cuò)誤信息進(jìn)行判斷鳄哭,只能是加大了找錯(cuò)誤的難度。

另外:VC中要編制程序不應(yīng)該一開(kāi)始就寫(xiě)cpp/h文件纲熏,而應(yīng)該首先創(chuàng)建一個(gè)合適的工程妆丘。因?yàn)橹挥羞@樣,VC才能選擇合適的編譯局劲、連接 選項(xiàng)勺拣。對(duì)于加入到工程中的cpp文件,應(yīng)該檢查是否在第一行顯式的包含stdafx.h頭文件鱼填,這是Microsoft Visual Studio為了加快編譯 速度而設(shè)置的預(yù)編譯頭文件药有。在這個(gè)#include "stdafx.h"行前面的所有代碼將被忽略,所以其他頭文件應(yīng)該在這一行后面被包含苹丸。

對(duì)于.c文件愤惰,由于不能包含stdafx.h,因此可以通過(guò)Project settings把它的預(yù)編譯頭設(shè)置為“不使用”赘理,方法是:

彈出Project settings對(duì)話(huà)框

選擇C/C++

Category選擇Precompilation Header

選擇不使用預(yù)編譯頭宦言。



注:轉(zhuǎn)自CSDN博客:http://blog.csdn.net/chocolateconanlan/article/details/4061545

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市商模,隨后出現(xiàn)的幾起案子奠旺,更是在濱河造成了極大的恐慌蜘澜,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件响疚,死亡現(xiàn)場(chǎng)離奇詭異兼都,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)稽寒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)趟章,“玉大人杏糙,你說(shuō)我怎么就攤上這事◎就粒” “怎么了宏侍?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)蜀漆。 經(jīng)常有香客問(wèn)我谅河,道長(zhǎng),這世上最難降的妖魔是什么确丢? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任绷耍,我火速辦了婚禮,結(jié)果婚禮上鲜侥,老公的妹妹穿的比我還像新娘褂始。我一直安慰自己,他們只是感情好描函,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開(kāi)白布崎苗。 她就那樣靜靜地躺著,像睡著了一般舀寓。 火紅的嫁衣襯著肌膚如雪胆数。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,071評(píng)論 1 285
  • 那天互墓,我揣著相機(jī)與錄音必尼,去河邊找鬼。 笑死轰豆,一個(gè)胖子當(dāng)著我的面吹牛胰伍,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播酸休,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼骂租,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了斑司?” 一聲冷哼從身側(cè)響起渗饮,我...
    開(kāi)封第一講書(shū)人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤但汞,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后互站,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體私蕾,經(jīng)...
    沈念sama閱讀 43,512評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評(píng)論 2 325
  • 正文 我和宋清朗相戀三年胡桃,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了踩叭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,094評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡翠胰,死狀恐怖容贝,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情之景,我是刑警寧澤斤富,帶...
    沈念sama閱讀 33,732評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站锻狗,受9級(jí)特大地震影響满力,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜轻纪,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評(píng)論 3 307
  • 文/蒙蒙 一油额、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧刻帚,春花似錦悔耘、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至校摩,卻和暖如春看峻,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背衙吩。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工互妓, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人坤塞。 一個(gè)月前我還...
    沈念sama閱讀 45,536評(píng)論 2 354
  • 正文 我出身青樓冯勉,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親摹芙。 傳聞我的和親對(duì)象是個(gè)殘疾皇子灼狰,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容