warning LNK4099: PDB 原因及解决方案
2015-10-17 10:54
176 查看
0x00 现象及原因
举例: warning LNK4099: PDB 'wxbase30ud.pdb' was not found with 'wxbase30ud.lib(any.obj)'
使用VC时链接了三方静态库, 并且三方静态库(一般是开源的三方库)是在一个solution下的多个project, 当然, 网上基本都是这么回答的, 其实本质原因是因为这些开源库一般都会通过各种方式修改solution和project的默认路径把二进制生成到同一个目录下, 比如lib, 而我们自己平时简单的静态库工程是不怎么修改默认工程配置的.
由于每个开源库的作者有自己的工程组织方式, 但导致LNK4099的最终原因无非是PDB路径问题
0x01 解决方案
a. 如果确认不需要PDB, 即不需要调试开源库, 完全可以在设置里将/Zi或/ZI去掉, 这样即能消除warning也能提升开源库编译速度
b. 如果需要调试开源库, 方法也不复杂
b.1. 将开源库project里的C/C++->General->Debug Information Format 设置为Zi或ZI(两者区别请自行google, Zi就够用了, 只是高版本的VS默认都是ZI)
b.2. 然后在C/C++->Output Files->Pragram Database File Name 设置为$(OutDir)$(TargetName).pdb, (有些2B开源库这里设置的跟VS默认的是一样的比如$(IntDir)vc$(PlatformToolsetVersion).pdb, 但把IntDir改成了同一个目录, 每个project生成出来的pdb名字路径都是一致的, 当然就会出问题), 这里需要注意的是, 一定要确保$(OutDir)$(TargetName)是有意义的, 个别开源库完全不用vs自带的宏,
甚至个别开源库需要configure之后才生产vc project, 甚至是绝对路径, 但你所要确保的是, 目录必须跟生成的.lib是同一个, 文件名(不包括扩展名)必须是和生成的xxx.lib的xxx是一致的. 之后你要做的就是把每个project的debug&release都按照如上改好再编译就ok了
0x02 总结
其实这个问题完全不是编译器或VS的事(这也说明了即使你disable 4099 waning依然还会报, 因为压根跟编译没关系), 就是路径错了, 改对就ok了.
网上绝大多数回答要不然就是跑题告诉你如何如何屏蔽不显示这个warning, 要不就是让你把obj目录拷过去(这个没用)等等, 都没鸟用
希望能有所帮助
举例: warning LNK4099: PDB 'wxbase30ud.pdb' was not found with 'wxbase30ud.lib(any.obj)'
使用VC时链接了三方静态库, 并且三方静态库(一般是开源的三方库)是在一个solution下的多个project, 当然, 网上基本都是这么回答的, 其实本质原因是因为这些开源库一般都会通过各种方式修改solution和project的默认路径把二进制生成到同一个目录下, 比如lib, 而我们自己平时简单的静态库工程是不怎么修改默认工程配置的.
由于每个开源库的作者有自己的工程组织方式, 但导致LNK4099的最终原因无非是PDB路径问题
0x01 解决方案
a. 如果确认不需要PDB, 即不需要调试开源库, 完全可以在设置里将/Zi或/ZI去掉, 这样即能消除warning也能提升开源库编译速度
b. 如果需要调试开源库, 方法也不复杂
b.1. 将开源库project里的C/C++->General->Debug Information Format 设置为Zi或ZI(两者区别请自行google, Zi就够用了, 只是高版本的VS默认都是ZI)
b.2. 然后在C/C++->Output Files->Pragram Database File Name 设置为$(OutDir)$(TargetName).pdb, (有些2B开源库这里设置的跟VS默认的是一样的比如$(IntDir)vc$(PlatformToolsetVersion).pdb, 但把IntDir改成了同一个目录, 每个project生成出来的pdb名字路径都是一致的, 当然就会出问题), 这里需要注意的是, 一定要确保$(OutDir)$(TargetName)是有意义的, 个别开源库完全不用vs自带的宏,
甚至个别开源库需要configure之后才生产vc project, 甚至是绝对路径, 但你所要确保的是, 目录必须跟生成的.lib是同一个, 文件名(不包括扩展名)必须是和生成的xxx.lib的xxx是一致的. 之后你要做的就是把每个project的debug&release都按照如上改好再编译就ok了
0x02 总结
其实这个问题完全不是编译器或VS的事(这也说明了即使你disable 4099 waning依然还会报, 因为压根跟编译没关系), 就是路径错了, 改对就ok了.
网上绝大多数回答要不然就是跑题告诉你如何如何屏蔽不显示这个warning, 要不就是让你把obj目录拷过去(这个没用)等等, 都没鸟用
希望能有所帮助
相关文章推荐
- 浅析JAVA中Str类型与in类型t之间转换
- HK面试经历
- Android之对话框的使用
- Supervisor启动进程的一些例子
- [TwistedFate]结构体,结构体数组,typedef
- IOS中延时执行的几种方式的比较和汇总
- vim集成开发环境搭建之字典翻译
- Java虚拟机中栈,栈帧,局部变量表的概念和特征。
- 计算结构体大小(字节对齐)
- Supervisor的一些实现逻辑
- 利用运行时设置UITextField 光标颜色
- android 更新并安装应用
- Android面试常见问题:如何在不发一个新版本的情况下更新App布局?
- hdu5441 离线处理+并查集
- DOM -----Document Object Model
- Supervisor的配置文件
- table布局
- 3.3.10 使用difflib.unified_diff函数
- 面对对象和面对过程的理解
- 3.3.10 使用difflib.unified_diff函数