前段时间,偶然遇到这样一个bug,我把静态库项目都配置好了,编译一切正常,但是提示了一个警告:
1>C:\Program Files (x86)\MSBuild\Microsoft.Cpp\v4.0\Microsoft.CppBuild.targets(1153,5): warning MSB8012: TargetName(stereo_vc9) 与 Library 的 OutputFile 属性值()不匹配。这可能导致项目生成不正确。若要更正此问题,请确保 $(OutDir)、$(TargetName) 和 $(TargetExt) 属性值与 %(Lib.OutputFile) 中指定的值匹配。
起初并没有在意,后来编译其他win32项目的时候,要用到这个库,结果让我大跌眼镜,提示我库找不到了,我比较奇怪,就去了指定路径下查看,果然没有!!
究竟是哪里出了问题?经过一番“折腾”,没发现任何错误的地方,没办法,只能与正确的静态库项目进行对比,我发现只有一处区别:
图1. 正常配置
图2. 异常配置
这是唯一的区别,我将输出文件写成相同的内容“$(OutDir)$(TargetName)$(TargetExt)”,重新编译,警告消失,编译通过,生成文件出现了!
知其然,更要知其所以然,根据警告内容“目标文件名stereo_vc9与lib的输出文件不符合”,VS2010中用了很多宏用于替代重要的参数或者路径,像 $(OutDir)、$(TargetName) 和 $(TargetExt) 分别指代了“目标文件夹所在路径”、“目标文件名”,“目标文件名后缀”,而$就代表提取对应宏的值。知道这些,原因就很清楚了,是由于“配置属性->常规->输出目录”、“配置属性->常规->目标文件名”、“配置属性->常规->目标文件扩展名”是与“$(OutDir)$(TargetName)$(TargetExt)”是一一对应的关系,为空自然会无法输出。
大家如果好奇,可以将“$(OutDir)$(TargetName)$(TargetExt)”替换为自己的路径(须与“配置属性->常规“中设置的不一致),输出的结果可能会没有,可能会以后者为优先,道理是一样的。
如果想查看宏的值究竟是什么,可以任意选择一个配置框,如下所示进行查看:
图3. 宏值
可能本文说的这个bug,早就有朋友注意到了,之所以写出来,是因为不希望大家因为这个问题浪费时间,太不值得了。