Visual Studio 2010 C++ 工程文件解读
在 VS2010 中,C++ 的工程文件已经和 2005 / 2008 有了很大的不同,而是完全采用 MSBUILD 的属性方式进行表达,并且可以让用户通过一次性的配置而对所有的属性进行自定义;
根据我的理解和实际使用中发现的一些信息,现整理成文与大家分享:
一、工程文件分为三个主要部分:初始化配置信息、默认配置信息和本地配置信息;
二、配置信息全部采用属性文件的方式进行组织,并且可以通过“导入”进行引用;
三、属性文件中可以包含工程属性、编译属性和链接属性的配置;
四、所有的配置项可以通过使用过滤条件来决定配置是否生效;
五、通过内置的表达式可以访问注册表或者调用.NET函数;
首先来说工程文件的组成
1、工程文件的起始部分是 ProjectConfigurations , 里面包含 Configuration(Debug 或者 Release)和 Platform(Win32、x64等),这个部分配置了工程编译目标的个数,默认配置只有两个:Win32 平台下的 Debug 和 Release;
2、其后是一切全局属性的配置,关键是 Keyword 属性,该属性决定了很多后续的默认属性文件的导入行为,例如是否导入 MFC 的默认属性设置;
3、导入 C++默认属性文件 Microsoft.Cpp.Default.props , 该文件在 C:\Program Files (x86)\MSBuild\Microsoft.Cpp\v4.0 目录下( Windows 64 上的默认安装位置,在你的机器上可能会有所不同,可以通过注册表 HKEY_LOCAL_MACHINE\Software\Microsoft\MSBuild\ToolsVersions\4.0 中的属性 VCTargetsPath 找到位置);
4、根据编译的配置不同进行一些本工程的特定配置,例如“ConfigurationType”、“CharacterSet”和"WholeProgramOptimization"
5、导入C++的属性文件 Microsoft.Cpp.props , 和默认属性文件 Microsoft.Cpp.Default.props 在相同的位置
6、根据编译的配置不同导入不同的用户配置属性文件,主要是根据平台的不同进行属性文件的导入,路径为 %LOCALAPPDATA%\Microsoft\MSBuild\v4.0\,这些文件没有配置任何的内容,如果你删除它们,那么在打开 C++ 工程文件时,IDE 会自动的创建它们;请注意关键就在这里,这些文件的目的就是为了用户可以对C++工程的属性进行自定义,并且是“用户”级别的,也就是说在这些文件中增加的属性将对你所有的工程起作用;
7、根据编译的配置不同对“编译”、“连接”、“库”等选项进行工程的本地配置,例如:“警告等级”、“优化选项”和“宏”的定义等;
8、工程中包含的文件,例如 ClCompile 包含的是需要进行 C/C++ 编译的文件,ResourceCompile 包含的是需要 RC 进行编译的资源文件,等等;
9、导入C++的编译目标属性定义文件“Microsoft.Cpp.targets”,和默认属性文件的位置相同;
好了,到此为止,工程文件的9个组成部分已经大致的分析出来了,如果对 Microsoft.Cpp.Default.props 、Microsoft.Cpp.props 和 Microsoft.Cpp.targets 进行简单分析就会发现,它们都是首先根据编译的目标平台导入对应的平台定义的文件,然后是自己的属性定义,并且这些属性都会在没有定义的情况下才会生效,避免冲掉前面的定义;并且还可以发现一个秘密,那就是在编译系统还为每一个工程提供了一个免费的属性定会以文件,*.vcxproj.user ,这个文件如果存在,那么将会被自动导入;
通过以上分析,我们可以发现C++的编译系统其实除了工程文件本身之外(毕竟不可能把所有的编译选项都放到工程文件中)还另外提供来三个级别的属性配置文件:
1、工程级别的,就是 *.vcxproj.user 文件;
2、用户级别的,就是 Microsoft.Cpp.$(Platform).user.props 文件
3、系统级别的,就是 前面提供到 Microsoft.Cpp.Default.props 、Microsoft.Cpp.props 和 Microsoft.Cpp.targets 文件;