在寫一個包含多個Project的程序時,采取分布編譯生成OBJ文件,然后主程序組裝,結果調(diào)試信息丟失。
warning LNK4099: PDB 'vc90.pdb' was not found with 'E:\Projects\XXXXX\Lib\log4cplusSD.lib' or at 'E:\Projects\XXXXX\Debug\vc90.pdb';
為解決這個問題搜索了下MSDN中關于PDB文件生成的一些解釋匯集在這里。
1)http://msdn.microsoft.com/zh-cn/library/yd4f8bd1(v=vs.80).aspx
程序數(shù)據(jù)庫 (PDB) 文件保存著調(diào)試和項目狀態(tài)信息,使用這些信息可以對程序的調(diào)試配置進行增量鏈接。當以 /ZI 或 /Zi(用于 C/C++)生成時,將創(chuàng)建一個 PDB 文件。
在 Visual C++ 中,/Fd 選項用于命名由編譯器創(chuàng)建的 PDB 文件。當使用向?qū)г?Visual Studio 中創(chuàng)建項目時,/Fd 選項被設置為創(chuàng)建一個名為 project.PDB 的 PDB。
如果使用生成文件創(chuàng)建 C/C++ 應用程序,并指定 /ZI 或 /Zi 而不指定 /Fd 時,則最終將生成兩個 PDB 文件:
每當創(chuàng)建 OBJ 文件時,C/C++ 編譯器都將調(diào)試信息合并到 VCx0.PDB 中。插入的信息包括類型信息,但不包括函數(shù)定義等符號信息。因此,即使每個源文件都包含公共頭文件(如 <windows.h>),這些頭文件中的 typedef 也只存儲一次,而不是在每個 OBJ 文件中都存在。
鏈接器將創(chuàng)建 project.PDB,它包含項目的 EXE 文件的調(diào)試信息。project.PDB 文件包含完整的調(diào)試信息(包括函數(shù)原型),而不僅僅是在 VCx0.PDB 中找到的類型信息。這兩個 PDB 文件都允許增量更新。鏈接器還在其創(chuàng)建的 .exe 或 .dll 文件中嵌入 .pdb 文件的路徑。
Visual Studio 調(diào)試器使用 EXE 或 DLL 文件中的 PDB 路徑查找 project.PDB 文件。如果調(diào)試器在該位置無法找到 PDB 文件或者如果路徑無效(例如,如果項目被移動到了另一臺計算機上),調(diào)試器將搜索包含 EXE 的路徑,即在“選項”對話框(“調(diào)試”文件夾,“符號”節(jié)點)中指定的符號路徑。調(diào)試器不會加載與所調(diào)試的二進制不匹配的 PDB。
2)http://msdn.microsoft.com/zh-cn/library/958x11bc(v=vs.80).aspx
下表描述了這些選項。
- 無
-
不產(chǎn)生任何調(diào)試信息,因此編譯較快。
- /Z7
-
生成包含用于調(diào)試器的完整符號調(diào)試信息的 .obj 文件。符號調(diào)試信息包括變量的名稱和類型以及函數(shù)和行號。不會生成任何 .pdb 文件。
對于第三方庫的發(fā)布者,不生成 .pdb 文件是一個優(yōu)點。但是,在鏈接和調(diào)試期間,用于預編譯頭的 .obj 文件是必需的。如果 .pch 對象文件中只有類型信息(沒有代碼),則還必須使用 /Yl(為調(diào)試庫插入 PCH 引用) 進行編譯。
- /Zi
-
產(chǎn)生包含用于調(diào)試器的類型信息和符號調(diào)試信息的程序數(shù)據(jù)庫 (PDB)。符號調(diào)試信息包括變量的名稱和類型以及函數(shù)和行號。
/Zi 不影響優(yōu)化。但是,/Zi 的確暗示了 /debug;有關更多信息,請參見 /DEBUG(生成調(diào)試信息)。
類型信息放置在 .pdb 文件而不是 .obj 文件中。
可以將 /Gm(啟用最小重新生成) 和 /Zi 結合使用,但使用 /Z7 編譯時不能使用 /Gm。
使用 /Zi 和 /clr 編譯時,DebuggableAttribute 屬性將不會被放入程序集元數(shù)據(jù)中;如果要使用該屬性,則必須在源代碼中指定它。該屬性可影響應用程序的運行時性能。有關 Debuggable 屬性如何影響性能以及如何減輕性能影響的更多信息,請參見令映像更易于調(diào)試。
- /ZI
-
以支持“編輯并繼續(xù)”功能的格式產(chǎn)生如上所述的程序數(shù)據(jù)庫。如果想使用“編輯并繼續(xù)”調(diào)試,則必須使用此選項。因為大多數(shù)優(yōu)化與“編輯并繼續(xù)”不兼容,所以使用 /ZI 會禁用代碼中的所有 #pragma optimize 語句。
/ZI 會導致在編譯中使用 /Gy(啟用函數(shù)級鏈接)。
/ZI 與 /clr(公共語言運行庫編譯) 不兼容。
注意 |
/ZI 只可用于面向 x86 的編譯器中;此編譯器選項不可用于面向 x64 或 Itanium 處理器系列 (IPF) 的編譯器中。 |
編譯器將程序數(shù)據(jù)庫命名為 project.pdb。如果編譯沒有項目的文件,則編譯器將創(chuàng)建名為 VCx0.pdb. 的數(shù)據(jù)庫,其中 x 是正在使用的 Visual C++ 的主版本。編譯器將 PDB 的名稱嵌入每個使用此選項創(chuàng)建的 .obj 文件中,從而使調(diào)試器了解符號和行號信息的位置。當使用此選項時,.obj 文件將較小,因為調(diào)試信息存儲在 .pdb 文件中而不是 .obj 文件中。
如果從使用此選項編譯的對象創(chuàng)建庫,則在將庫鏈接到程序時,關聯(lián) .pdb 文件必須可用。因此,如果發(fā)布此庫,就必須發(fā)布 PDB。
若要不使用 .pdb 文件創(chuàng)建包含調(diào)試信息的庫,必須選擇編譯器的 C 7.0 兼容 (/Z7) 選項。如果使用預編譯頭選項,則預編譯頭和其他源代碼的調(diào)試信息都放在 PDB 中。指定了“程序數(shù)據(jù)庫”選項時將忽略 /Yd 選項。
3)http://msdn.microsoft.com/zh-cn/library/dd998269.aspx
/PDBALTPATH(使用備用 PDB 路徑)
/PDBALTPATH:pdb_file_name
其中:
- pdb_file_name
-
.pdb 文件的路徑和文件名。
使用此選項可以在已編譯二進制文件中為程序數(shù)據(jù)庫 (.pdb) 文件提供一個備用位置。 通常,鏈接器將 .pdb 文件的位置記錄到它所生成的二進制文件中。 使用此選項可以為程序數(shù)據(jù)庫文件提供另一個路徑和文件名。 /PDBALTPATH 提供的信息不會更改實際 .pdb 文件的位置或名稱;它更改鏈接器寫入二進制文件中的信息。 這樣,您可以提供一個獨立于生成計算機文件結構的路徑。 此選項的兩個常見用途是提供網(wǎng)絡路徑或不包含路徑信息的文件。
pdb_file_name 的值可以是任意字符串,也可以是環(huán)境變量(即 %_PDB%)。 鏈接器將環(huán)境變量(如 %SystemRootr%)擴展為它的值。 鏈接器定義環(huán)境變量 %_PDB% 和 %_EXT%。 %_PDB% 擴展為實際 .pdb 文件的文件名(不包含任何路徑信息),%_EXT% 是所生成的可執(zhí)行文件的擴展名。