使用VS2008在一个解决方案中包含多个项目时,当设置多个项目的中间目录为同一个目录时,在增量编译时出现“从新编译时vc90.pdb不是建立此预编译头时使用的pdb文件,请从新建立预编译头问题”,从而致使整个解决方案每次都必须从新所有生成。ide
在msdn上得到以下信息:ui
You may receive a "PRJ0008" or "C2471" or "C1083" or "D8022" or "LNK1103" or similar error message when you try to build a solution in Visual C++ debug
Symptoms: orm
- D8022 : Cannot open 'RSP00000215921192.rsp'
- PRJ0008 : Could not delete file 'vc90.idb'.
- C1083 : Cannot open program database file 'vc90.pdb'
- C2471 : Cannot update program database 'vc90.pdb'
- LNK1103 : debugging information corrupt.
Cause: three
This problem occurs when all of the following conditions are true: ip
- You have a solution with more than one project in it.
- Two or more of the projects are not dependent on each other.
- You have parallel builds enabled. (Tools -> Options: Projects and Solutions, Build and Run: "maximum number of parallel project builds" is set to a value greater than 1)
- You are building on a system with multiple CPUs (cores).
- Two or more of the non-dependent projects are configured to use the same Intermediate and/or Output directory.
- A specific race condition in mspdbsrv.exe remains uncorrected.
Resolution: ci
To resolve the problem do one or more of the following: rem
- Reconfigure the non-dependent projects to specify an Intermediate and Output directory that is different from one another, e.g. Output Directory = "$(SolutionDir)$(ProjectName)\$(ConfigurationName)", Intermediate Directory = "$(OutDir)".
- Adjust your solution's project dependencies (Project -> Project Dependencies...) so that each is dependent on another.
- Disable parallel builds.
- Add the "/onecpu" boot option to your boot.ini file.
- Change you BIOS settings to enable/use only one CPU.
- File a problem report with Microsoft Technical Support and keep bugging the ____ out of them until they eventually fix mspdbsrv.
Status: get
The problem is a combination of both a user project configuration error as well as a race condition in Microsoft's "mspdbsrv.exe" utility that does not properly handle more than one thread calling it at the same time for the same file resulting in the file's HANDLE being left open. it
Additionally Visual Studio itself and/or its build system (VCBUILD and/or MSBUILD) (or all three!) should be made smart enough to detect and alert the user of such user errors so that corrective action can be taken.
This problem has been around for a LOOOOOONG time.
Applies to:
- Microsoft Visual C++ 2005
- Microsoft Visual C++ 2008
- Others?
Respectfully submitted:
"Fish" (David B. Trout)
fish@infidels.org
p.s:
You're welcome. :)
Fish (David B. Trout)
最后,经过从新配置项目的中间输出目录成功解决上述问题。
遗留问题:在每一个项目生成时,在对应的中间目录下都会生成vc90.pdb以及vc90.idb文件,若是所有项目的中间目录配置成相同目录,在项目依次生成过程当中,后面生成的pdb文件会覆盖前面生成的pdb文件,从而致使修改部分源代码时,pdb文件可能再也不是其对应项目生成的文件,所以须要从新生成整个解决方案。纯属猜想,后续能够使用逐步生成项目的方式验证结论。
https://social.msdn.microsoft.com/Forums/vstudio/en-US/25731965-bf98-4bb7-97b7-6d1a0b21b733/cant-open-vc90pdb-in-visual-c-2008-rebuild?forum=vcgeneral