https://msdn.microsoft.com/zh-cn/library/windows/hardware/ff552873(v=vs.85).aspx
有两种常规符号文件系统。在本文中,这两种系统称为“当前系统”和“旧系统”。
当前符号文件系统
在当前系统中,始终有两种文件:可执行文件和 .pdb 文件。.pdb 文件包含所有符号。可执行文件包含指向 .pdb 文件的指针。
如果 .pdb 符号文件包含专用符号,则 BinPlace 可以将此信息剥离出来并生成剥离符号文件。有关详细信息,请参阅公用符号和专用符号。
旧符号文件系统
在旧系统中,可以通过两种方式排列可执行文件和符号文件:
-
可执行文件和 .pdb 文件。在此排列中,大多数符号信息位于 .pdb 文件中。其余的符号信息包含在可执行文件中。可执行文件还包含指向 .pdb 文件的指针。
-
可执行文件、.pdb 文件和 .dbg 文件。.pdb 文件与双文件排列内的文件相同:它包含大部分符号。其余的符号信息包含在 .dbg 文件中。可执行文件中不包含任何符号信息。可执行文件包含指向 .dbg 文件的指针,并且 .dbg 文件包含指向 .pdb 文件的指针。
在旧符号文件系统中,双文件排列和三文件排列均包含相同的可执行代码和相同的符号。程序可以运行并在任一排列中调试。但是,三文件排列执行速度更快,因为可执行文件较小。
如果使用旧符号文件系统(双文件排列)构建二进制文件,则 BinPlace 可以将其转换为三文件排列。换句话说,BinPlace 可以将可执行文件“拆分”为无符号可执行文件和包含可执行文件中的符号的新 .dbg 文件。
BinPlace 还可以从旧符号文件系统中的文件中剥离专用符号信息,但这仅在它还拆分文件的情况下发生(即,仅在从双文件排列更改为三文件排列的情况下)。BinPlace 无法剥离旧符号文件系统中文件的专用符号并将其保留在双文件排列中。并且,如果文件已采用三文件排列,则 BinPlace 不会实际执行任何剥离操作;如果可执行文件在 BinPlace 命令行上命名,甚至不能移动符号文件。有关详细信息,请参阅公用符号和专用符号。