Visual C++開(kāi)發(fā)工具與調試技巧整理
自己總是用VC平臺來(lái)開(kāi)發(fā)東西,但是有時(shí)候總是出這樣那樣的問(wèn)題,呵呵,總是需要上網(wǎng)查資料來(lái)解決,在這里把自己用到上網(wǎng)查的一些技巧摘錄如下,希望對大家有用,省去大家再去搜索的煩惱。
1.如何在Release狀態(tài)下進(jìn)行調試
Project->Setting=>ProjectSetting對話(huà)框,選擇Release狀態(tài)。C/C++標簽中的Category選General,Optimizations選Disable(Debug),Debut info選Program Database。在Link標簽中選中Generate debug info復選框。
注:只是一個(gè)介乎Debug和Release的中間狀態(tài),所有的ASSERT、VERIFY都不起作用,函數調用方式已經(jīng)是真正的調用,而不查表,但是這種狀態(tài)下QuickWatch、調用隊列跟蹤功能仍然有效,和Debug版一樣。
2. Release和Debug有什么不同
Release版稱(chēng)為發(fā)行版,Debug版稱(chēng)為調試版。
Debug中可以單步執行、跟蹤等功能,但生成的可執行文件比較大,代碼運行速度較慢。Release版運行速度較快,可執行文件較小,但在其編譯條件下無(wú)法執行調試功能。
Release的exe文件鏈接的是標準的MFC DLL(Use MFC in a shared or static dll)。這些DLL在安裝Windows的時(shí)候,已經(jīng)配置,所以這些程序能夠在沒(méi)有安裝Visual C++ 6.0的機器上運行。而Debug版本的exe鏈接了調試版本的MFC DLL文件,在沒(méi)有安裝Visual C++6.0的機器上不能運行,因為缺相應的DLL,除非選擇use static dll when link。
3. ASSERT和VERIFY有什么區別
ASSERT里面的內容在Release版本中不編譯,VERIFY里面的內容仍然翻譯,但不再判斷真假。所以后者更安全一點(diǎn)。
例如ASSERT(file.Open(strFileName))。
一旦到了Release版本中,這一行就忽略了,file根本就不Open()了,而且沒(méi)有任何出錯的信息。如果用VERIFY()就不會(huì )有這個(gè)問(wèn)題。
4.Workspace和Project之間是什么樣的關(guān)系
每個(gè)Workspace可以包括幾個(gè)project,但只有一個(gè)處于Active狀態(tài),各個(gè)project之間可以有依賴(lài)關(guān)系,在project的Setting..中可以設定,比如那個(gè)Active狀態(tài)的project可以依賴(lài)于其他的提供其函數調用的靜態(tài)庫。
5. 如何在非MFC程序中使用ClassWizard
在工程目錄下新建一個(gè)空的.RC文件,然后加入到工程中就可以了。
6.如何設置斷點(diǎn)
按F9在當前光標處增加一個(gè)斷點(diǎn)和取消一個(gè)斷點(diǎn)。
另外,在編輯狀態(tài)下,按Ctrl+B組合鍵,彈出斷點(diǎn)設置對話(huà)框。然后單擊【Condition…】按鈕彈出設置斷點(diǎn)條件的對話(huà)框進(jìn)行設置。
7.在編輯狀態(tài)下發(fā)現成員變量或函數不能顯示提示是如何打開(kāi)顯示功能
這似乎是目前這個(gè)Visual C++ 6.0版本的一個(gè)bug,可按如下步驟使其正常,如再出現,可如法炮制:
(1)關(guān)閉Project
(2)刪除“工程名.ncb”文件
(3)重新打開(kāi)工程
8.如何將一個(gè)通過(guò)ClassWizard生成的類(lèi)徹底刪除
首先在工作區的FileView中選中該類(lèi)的.h和.cpp文件,按delete刪除,然后在文件管理器中將這兩個(gè)文件刪除,再運行ClassWizard,這時(shí)出現是否移走該類(lèi)的提示,選擇remove就可以了。
9. 如何將在workspace中消失的類(lèi)找出來(lái)
打開(kāi)該類(lèi)對應的頭文件,然后將其類(lèi)名隨便改一下,這個(gè)時(shí)候工作區就會(huì )出現新的類(lèi),再將這個(gè)類(lèi)改回原來(lái)的名字就可以了。
10. 如何清除所有的斷點(diǎn)
菜單【Edit】->【Breakpoints…】,打開(kāi)“Breakpoints”對話(huà)框,單擊【Remove All】按鈕即可??旖萱I是“Ctrl + Shift + F8”。
11. 如何再ClassWizard中選擇未列出的信息
打開(kāi)“ClassWizard”對話(huà)框,然后切換到“Class Info”頁(yè)面。改變“Message filter”,如選擇“Window”,“Message”頁(yè)面就會(huì )出現Window的信息。
12. 如何檢測程序中的括號是否匹配
把光標移動(dòng)到需要檢測的括號前面,按快捷鍵“Ctrl + ]”。如果括號匹配正確,光標就跳到匹配的括號處,否則光標不移動(dòng),并且機箱喇叭還會(huì )發(fā)出一聲警告。
13. 如何查看一個(gè)宏(或變量、函數)的定義
把光標移動(dòng)到要查看的一個(gè)宏上,就比如說(shuō)最常見(jiàn)的DECLARE_MAP_MESSAGE上按一下F12(或右鍵菜單中的相關(guān)菜單),如果沒(méi)有建立瀏覽文件,就會(huì )出現提示對話(huà)框,按【確定】按鈕,然后就會(huì )跳到該宏(或變量、函數)定義的地方。
14. 如何添加Lib文件到當前工程
單擊菜單【Project】->【Settings…】彈出“Project Setting”對話(huà)框,切換到“Link”標簽頁(yè),在“Object/library modules”處輸入Lib文件名稱(chēng),不同的Lib之間用空格格開(kāi)。
15. 如何快速刪除項目下的Debug文件夾中臨時(shí)文件
在工作區的FileView視圖中選中對應的項目,單擊右鍵彈出菜單,選擇【Clean(selection only)】菜單即可。
16. 如何快速生成一個(gè)現有工程除了工程名外完全相同的新工程
在新建工程的“New”對話(huà)框中選擇“Custom Appwizard”項,輸入新工程的名字,單擊【OK】按鈕。出現“Custom AppWizard”項,輸入新工程的名字,單擊【OK】按鈕。出現“Custom AppWizard-Step 1 of 2”對話(huà)框,選擇“An existing Project”項,單擊【Next】按鈕。出現“Custom AppWizard-Step 2 of 2”對話(huà)框,選擇現有工程的工程文件名,最后單擊【Finish】按鈕。編譯后就生成一個(gè)與現有工程相同但可以重新取名的工程AppWizard。
現在就可以項用MFC AppWizard一樣用這個(gè)定制的向導。如果不想用了,可以在Visual C++ 6.0安裝目錄下Common\MSDev98\Template目錄中刪除該Wizard對應的.awx和.pdb文件。
17. 如何解決Visual C++ 6.0不正確連接的問(wèn)題
情景:明明改動(dòng)了一個(gè)文件,卻要把整個(gè)項目全部重新編譯鏈接一次。剛剛鏈接好,一運行,又提示重新編譯鏈接一次。
這是因為出現了未來(lái)文件(修改時(shí)間和創(chuàng )建時(shí)間比系統時(shí)間晚)的緣故??梢赃@樣處理:找到工程文件夾下的debug目錄,將創(chuàng )建和修改時(shí)間都比系統時(shí)間的文件全部刪除,然后再從新“Rebuild All”一次。
18. 引起LNK2001的常見(jiàn)錯誤都有哪些
遇到的LNK2001錯誤主要為:unresolved external symbol “symbol”
如果鏈接程序不能在所有的庫和目標文件內找到所引用的函數、變量或標簽,將產(chǎn)生此錯誤信息。
一般來(lái)說(shuō),發(fā)生錯誤的原因有兩個(gè):一是所引用的函數、變量不存在,拼寫(xiě)不正確或者使用錯誤;其次可能使用了不同版本的鏈接庫。以下是可能產(chǎn)生LNK2001錯誤的原因:
<1>由于編碼錯誤導致的LNK2001錯誤
(1)不相匹配的程序代碼或模塊定義(.DEF)文件導致LNK2001。例如,如果在C++源文件了內聲明了一變量“var1”,卻試圖在另一個(gè)文件內以變量“var1”訪(fǎng)問(wèn)改變量。
(2)如果使用的內聯(lián)函數是在.cpp文件內定義的,而不是在頭文件內定義將導致LNK2001錯誤。
(3)調用函數時(shí)如果所用的參數類(lèi)型和頭函數聲明時(shí)的類(lèi)型不符將會(huì )產(chǎn)生LNK2001錯誤。
(4)試圖從基類(lèi)的構造函數或析構函數中調用虛擬函數時(shí)將會(huì )導致LNK2001錯誤。
(5)要注意函數和變量的可公用性,只有全局變量、函數是可公用的。靜態(tài)函數和靜態(tài)變量具有相同的使用范圍限制。當試圖從文件外部方位任何沒(méi)有在該文件內聲明的靜態(tài)變量時(shí)將導致編譯錯誤或LNK2001錯誤。
<2>由于編譯和聯(lián)機的設置而造成的LNK2001錯誤
(1)如果編譯時(shí)使用的是/NOD(/NODERAULTLIB)選項,程序所需要的運行庫和MFC時(shí)將得到又編譯器寫(xiě)入目標文件模塊,但除非在文件中明確包含這些庫名,否則這些庫不會(huì )被鏈接進(jìn)工程文件。這種情況下使用/NOD將導致LNK2001錯誤
(2)如果沒(méi)有為wWinMainCRTStartup設定程序入口,在使用Unicode和MFC時(shí)將出現“unresolved external on _WinMain@16”的LNK2001錯誤信息。
(3)使用/MD選項編譯時(shí),既然所有的運行庫都被保留在動(dòng)態(tài)鏈接庫之內,源文件中對“func”的引用,在目標文件里即對“__imp__func”的引用。如果試圖使用靜態(tài)庫LIBC.LIB或LIBCMT.LIB進(jìn)行鏈接,將在__imp__func上發(fā)生LNK2001錯誤。如果不使用/MD選項編譯,在使用MSVCxx.LIB鏈接時(shí)也會(huì )發(fā)生LNK2001錯誤。
(4)使用/ML選項編譯時(shí),如用LIBCMT.LIB鏈接會(huì )在_errno上發(fā)生LNK2001錯誤。
(5)當編譯調試版的應用程序時(shí),如果采用發(fā)行版模態(tài)庫進(jìn)行鏈接也會(huì )產(chǎn)生LNK2001錯誤;同樣,使用調試版模態(tài)庫鏈接發(fā)行版應用程序時(shí)也會(huì )產(chǎn)生相同的錯誤。
(6)不同版本的庫和編譯器的混合使用也能產(chǎn)生問(wèn)題,因為新版的庫里可能包含早先的版本沒(méi)有的符號和說(shuō)明。
(7)在不同的模塊中使用內聯(lián)和非內聯(lián)的編譯選項能夠導致LNK2001錯誤。如果創(chuàng )建C++庫時(shí)打開(kāi)了函數內聯(lián)(/Ob1或/Ob2),但是在描述該函數的相應頭文件里卻關(guān)閉了函數內聯(lián)(沒(méi)有inline關(guān)鍵字),只是將得到錯誤信息。為避免該問(wèn)題的發(fā)生,應該在相應的頭文件中用inline關(guān)鍵字標志為內聯(lián)函數。
(8)不正確的/SUBSYSTEM或ENTRY設置也能導致LNK2001錯誤。
19. 如何調試一個(gè)沒(méi)有源碼的exe文件調用的dll
在Visual C++ 6.0中,進(jìn)入“Project Setting”對話(huà)框然后選擇Debug標簽頁(yè)。通常Visual Studio默認“executable for debug session”為可執行文件名,但可以將他改成任何你想要的程序。甚至可以指定不同的工作目錄以及傳遞參數到你的程序。這個(gè)技術(shù)常用來(lái)調試Dlls、名字空間擴展、COM對象和其他從某些EXE以及從第三方的EXE中調用的plug-in程序。
20. Visual C++ 6.0工程中的項目文件都表示什么
.opt:工程關(guān)于開(kāi)發(fā)環(huán)境的參數文件。如工具條位置等信息。
.aps(AppStudio File)資源輔助文件,二進(jìn)制格式,一般不用去管它。
.clw:ClassWizard信息文件,實(shí)際上是INI文件格式,有興趣可以研究一下。有時(shí)候ClassWizard出了問(wèn)題,手工修改CLW文件可以解決。如果此文件不存在的話(huà),每次用ClassWizard的時(shí)候回提示是否重建。
.dsp(DevelopStudio Project):項目文件,文本格式,不過(guò)不熟悉的不要手工修改。
.dsw(DevelopStudio Workspace):是工作區文件,其他特點(diǎn)和.dsp差不多。
.plg:是編譯信息文件,編譯時(shí)的error和warning信息文件(實(shí)際上是一個(gè)html文件),一般用處不大。在單擊菜單【Tool】->【Option】彈出的對話(huà)框里面有個(gè)選項可以控制這個(gè)文件的生成。
.hpj(Help Project):是生成幫助文件的工程,用microsoft Help Compiler可以處理。
.mdp(Microsoft DevStudio Project):是舊版本的項目文件,如果要打開(kāi)此文件的話(huà),會(huì )提示你是否轉換成新的.dsp格式。
.bsc:是用于瀏覽項目信息的,如果用Source Brower的話(huà)就必須有這個(gè)文件。如果不用這個(gè)功能的話(huà),可以在Project Options里面去掉Generate Browse Info File,這樣可以加快編譯速度。
.map是執行文件的映象信息記錄文件,除非對系統底層,這個(gè)文件一般用不著(zhù)。
.pch(Pre-Compiled File):是與編譯文件,可以加快編譯速度,但是文件非常大。
.pdb(Program Database):記錄了程序有關(guān)的一些數據和調試信息,在調試的時(shí)候可能有用。
.exp:只有在編譯DLL的時(shí)候才會(huì )生成,記錄了DLL文件的一些信息,一般也沒(méi)有用。
.ncb:無(wú)編譯瀏覽文件(no compile browser)。當自動(dòng)完成功能出問(wèn)題時(shí)可以刪除此文件。編譯工程后會(huì )自動(dòng)生成。