詳解Visual Studio調(diào)試中符號文件的作用
對于Visual Studio調(diào)試過程中的一些步驟,我們今天需要了解的是符號文件,希望通過本文,能為大家的工作起到事半功倍的效果。
前面在不能設(shè)置斷點的檢查步驟和Visual Studio調(diào)試之?dāng)帱c進(jìn)階篇提到了調(diào)試符號文件及其作用,這篇文章我將要介紹調(diào)試符號文件的一些用法,如果你已經(jīng)很熟悉調(diào)試文件的話,盡可以跳過本文。
調(diào)試符號文件為調(diào)試器提供了從二進(jìn)制機(jī)器代碼地址到源代碼文本文件代碼行的映射.因此有了符號文件,我們才能:
1. 設(shè)置斷點,因為調(diào)試器需要符號文件提供的映射關(guān)系,將源代碼行的行號轉(zhuǎn)換成對應(yīng)的機(jī)器代碼的地址。
2. 查看程序堆棧,簡單地說,就是調(diào)試器使用映射關(guān)系將堆棧里面的地址轉(zhuǎn)換成包含這個地址的函數(shù)名。
3. 查看變量的值,對于機(jī)器來說,所有的變量都只是一個內(nèi)存地址,程序在讀取變量值的時候,只不過按照變量所屬的類型來讀取指定大小的內(nèi)存而已。
4. 甚至調(diào)用程序的一些函數(shù),比如原生(Native)程序,經(jīng)過編譯以后,在程序里面實際上只變成了一段機(jī)器代碼。我們在立即窗口里面調(diào)用一個C++函數(shù)的時候,調(diào)試器需要將函數(shù)名翻譯成對應(yīng)的機(jī)器代碼的起始地址,當(dāng)然還要遵循一定的函數(shù)調(diào)用規(guī)則才能調(diào)用這個函數(shù)。
我們一個一個地看符號文件的功能:
查看程序堆棧將Visual Studio以原生程序(Native)調(diào)試模式附加到一個已打開的記事本程序上(附:因為我的系統(tǒng)都是英文版,所以中文菜單都是對著英語直接翻譯的,有的會翻譯的不準(zhǔn)確,所以我會把英文的命令附在后面),然后中斷記事本進(jìn)程的執(zhí)行 — 通過點擊VS菜單里面的“調(diào)試(Debug)”-“全部中斷(Break All)”。
下面是具體的將VS附加到記事本進(jìn)程的操作(不好意思,錄制的視頻太大,不知道怎么傳)。
1. 點擊Visual Studio里面的“工具(Tools)”- “附加到進(jìn)程……(Attach to Process …)”。
2. 選擇notepad.exe,當(dāng)然你要保證“附加到… (Attach To…)” 文本框里面列出的調(diào)試類型是“原生程序(Native)”。
3.點擊確定以后,將Visual Studio附加到剛剛打開的記事本進(jìn)程。
這個時候打開堆棧(Stack)窗口,你應(yīng)該會看到類似下面的結(jié)果:
上面的堆棧,我也看不懂(我的機(jī)器是64位的Windows 7,所以地址都是8個字節(jié)的)。因此我們需要一些東西來幫我們把難理解的地址(鳥語)翻譯成有意義的文字,這個工作就是由符號文件來完成的。
因為記事本是操作系統(tǒng)自帶的程序,我們當(dāng)然沒有辦法自己生成它對應(yīng)的符號文件啦,但是幸運(yùn)的是,微軟早就已經(jīng)考慮到可能有一些人需要調(diào)試Windows內(nèi)核—例如寫驅(qū)動程序的程序員,因此微軟公司已經(jīng)將Windows的一些符號文件公開了,公開的地址在:
http://msdl.microsoft.com/download/symbols
在Visual Studio里使用的方法是:
1.點擊菜單欄里面的“工具(Tools)”—“選項(Options)”。
2.在“選項(Options)”對話框左邊的列表框里面選擇“調(diào)試(Debugging)”-“符號文件(Symbols)”。
3.如果你的Visual Studio是Visual Studio 2008 SP 1,那么點擊“從微軟的符號文件服務(wù)器上加載符號文件(Load symbols from Microsoft symbols server)”就可以了。
4. 如果是其他版本-當(dāng)然是低一些的版本,在右側(cè)的“符號文件路徑(Symbol file (.pdb) locations)”列表框里面添加新的一行,將上面的鏈接輸入進(jìn)去。
然后在“將符號文件緩存到這個文件夾(Cache symbols from symbol servers to this directory:)”文本框里輸入你要緩存從服務(wù)器下載的符號文件的文件夾路徑—畢竟那個服務(wù)器是在美國。如下圖所示:
5.點擊“確定( OK)”
6. 對于聽說英文沒有困難的朋友,可以直接參考下面的鏈接學(xué)習(xí)如何設(shè)置:http://support.microsoft.com/kb/311503/zh-cn
等待一段很長的時間以后—因為調(diào)試器要一個個下載記事本程序所引用到的所有動態(tài)鏈接庫文件的符號文件,你應(yīng)該可以看到類似下面的堆棧信息:
這篇文章的描述里面,我希望你能夠明白調(diào)試符號文件的重要性:
1. 如果沒有調(diào)試符號文件,那么就不能查看堆棧—這話好像有點多余。但是很多時候,我們在分析驗尸調(diào)試所保存的內(nèi)存文件的時候,第一步要看檢查的就是,程序崩潰的時候,堆棧是什么樣子的,如果沒有調(diào)試符號文件,那我們就什么也做不了了。
2. 那么調(diào)試符號文件是如何生成的呢?調(diào)試符號文件是由編譯器生成的,因為編譯器負(fù)責(zé)將文本格式的源代碼文件翻譯成二進(jìn)制的程序,所以二者之間的映射關(guān)系編譯再清楚不過了。每次重新編譯的時候,編譯器都會生成對應(yīng)的調(diào)試符號文件。
生成調(diào)試符號文件的命令:
編程語言 |
編譯器 |
命令行參數(shù) |
C# |
csc.exe |
/debug[:full] |
C++/C |
cl.exe |
/Zi 或者 Link.exe的/debug選項 |
3.例如一個客戶跟你抱怨程序不能工作,出現(xiàn)了嚴(yán)重的錯誤(Bug),但是他正在運(yùn)行的是1.0版本的程序,而你們公司卻已經(jīng)再開發(fā)2.0版本的程序了。由于源代碼一般都不會給客戶,這個時候如果能夠找到原始的1.0 版本的源代碼重新編譯,然后安裝到客戶機(jī)重現(xiàn)一下固然是好,但是為什么不直接保存1.0版本的調(diào)試符號文件,在調(diào)試的時候,直接讓調(diào)試器自己去找源代碼呢?這里涉及到符號文件服務(wù)器和源代碼文件服務(wù)器的合作問題,后面的文章里可能會介紹到。
原文標(biāo)題:Visual Studio調(diào)試之符號文件
鏈接:http://www.cnblogs.com/killmyday/archive/2009/10/14/1582882.html
【編輯推薦】