溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

.NET PDB文件是什么

發(fā)布時(shí)間:2021-07-23 09:54:49 來源:億速云 閱讀:127 作者:chen 欄目:編程語言

這篇文章主要講解了“.NET PDB文件是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“.NET PDB文件是什么”吧!

PDB全稱Program Database,不知道中文翻譯叫什么。相信使用過VS的人對于這個(gè)拓展名的文件不會陌生,這個(gè)文件主要會存儲對應(yīng)模塊(dll或者exe)內(nèi)部的所有符號,以及符號對應(yīng)的地址、文件名和行號。

這個(gè)文件會在我們調(diào)試的時(shí)候被使用到,這個(gè)東西可以理解為調(diào)試的時(shí)候應(yīng)用程序和源文件之間的一個(gè)橋梁。正是歸功于這個(gè)文件,我們才能在debug的時(shí)候看到程序當(dāng)前執(zhí)行相對應(yīng)的代碼和監(jiān)視到一些變量。

PDB文件什么時(shí)候產(chǎn)生?

PDB文件是在我們編譯工程的時(shí)候產(chǎn)生的,它是和對應(yīng)的模塊(exe或dll)一起生成出來的。我們一般可能不會意識到PDB文件的重要性,因?yàn)槿绻皇俏覀儽镜剡M(jìn)行開發(fā),我們總是能夠進(jìn)行調(diào)適。這里我要引入兩個(gè)概念:Private Build和Public Build。Private Build指的是在開發(fā)機(jī)器上的編譯,Public Build指的是在負(fù)責(zé)編譯的機(jī)器上的編譯。

正如上面我所說Private Build一般不會有問題,因?yàn)樵诰幾g出來的機(jī)器上進(jìn)行調(diào)試所有必要的文件都在該在的地方。所有大部分不能調(diào)試的問題都發(fā)生在Public Build的情況下。

如果你的應(yīng)用程序需要發(fā)布或者當(dāng)作產(chǎn)品賣得,你就需要特別注意要保存你發(fā)布出去的那個(gè)版本的PDB文件和源文件。注意:你只有一次機(jī)會保存著發(fā)布出去的PDB文件,如果你弄丟了將無法找回。<當(dāng)然使用Reflector 類似的工具去調(diào)試也是可以的>

為什么PDB這么重要?

也許你會認(rèn)為如果拿一份一模一樣的源代碼重新編譯一個(gè)PDB文件,然后用來調(diào)試就行了。我也曾經(jīng)這么認(rèn)為過,直到有一天&hellip;......

直接的原因是因?yàn)閂S生成出來的二進(jìn)制文件的Header部分里面包含了它對應(yīng)的PDB的GUID,PDB也包含一個(gè)GUIID,這兩個(gè)GUID實(shí)在編譯的時(shí)候添加進(jìn)去的。VS調(diào)試器在載入PDB的時(shí)候會去比對這個(gè)兩個(gè)GUID,如果不一致,那么就不能使用。

當(dāng)然上面那個(gè)原因只是一個(gè)表面現(xiàn)象,根本原因是既是兩份一模一樣的代碼編譯器編譯出來的文件可能是不一樣的。因?yàn)榫幾g器在編譯的時(shí)候會對代碼進(jìn)行優(yōu)化,而同一份代碼可能會有很多種優(yōu)化的方法,它會根據(jù)當(dāng)時(shí)的具體機(jī)器的環(huán)境等情況選擇一個(gè)最快的生成方法。所以它生成出來的文件有可能是不一樣的!所以如果連生成出來的文件都不一樣,那么原來的那個(gè)PDB里面的符號對應(yīng)的地址也就沒有意義了。

如何查看二進(jìn)制文件和PDB的GUID?

使用VS自帶的DUMPBIN工具可以查看二進(jìn)制文件所期望的PDB的GUID?;居梅ň褪荄UMPBIN /HEADER 文件,具體用可可參考MSDN。

查看PDB的GUID可以用下面這個(gè)工具,直接將PDB拉進(jìn)去即可。http://www.codeproject.com/Articles/37456/How-To-Inspect-the-Content-of-a-Program-Database-P

PDB文件的查找策略

先上試驗(yàn)結(jié)果,可以再調(diào)試的時(shí)候從Visual Studio 的Module串口中查找到一個(gè)module的symbol的查找策略。從截圖中我們可以看到結(jié)果如下:

.NET PDB文件是什么

1. 文件被執(zhí)行或者被載入的地址

2. 就是硬編碼在PE文件頭中的那個(gè)地址。大家可以看到obj\<config>才是最原始生成的地址,只是之后被拷貝到了***個(gè)地址中去了。

2.5 如果配置了符號服務(wù)器,第二步以后應(yīng)該先去符號服務(wù)器的緩存目錄下找,如果找不到再去符號服務(wù)器上去找。找到的話就會下載到緩存目錄。

3. 第三部分是我VS中設(shè)置的一些符號查詢的目錄,因?yàn)槲已b過Reflector所以默認(rèn)加了這幾個(gè)目錄在我的設(shè)置中。

4. Windows文件夾。

這里有一個(gè)比較有意思的現(xiàn)象就是,VS的查找策略都是會先找一個(gè)目錄下的symbol\exe\project.pdb,然后exe\project.pdb,***才找project.pdb。這個(gè)順序有點(diǎn)出人意料。

PDB文件會影響性能么?

可能有些人會覺得PDB文件的生成會對最終的應(yīng)用程序的性能產(chǎn)生一定的影響,所以覺得在發(fā)布版中不應(yīng)該生成PDB文件。

錯(cuò)!對于.NET應(yīng)用程序來說,生成PDB文件不會影響編譯器的優(yōu)化,所以也完全不會影響應(yīng)用的性能。只會對于生成的程序集中的一個(gè)DebuggableAttribute的屬性產(chǎn)生影響。有興趣的人可以閱讀Do PDB Files Affect Performance?

感謝各位的閱讀,以上就是“.NET PDB文件是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對.NET PDB文件是什么這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI