诡异的Visual Studio 的调试bug
2009-07-17 16:06
246 查看
工程结构
包含有静态库motion.lib 一个UI逻辑的库
HGErender.lib 使用一个motion的接口实现的HGE渲染器,与motion.lib没有链接和依赖关系
一个exe静态链接motion.lib和HGErender.lib
motion中加入了一些flash支持,将flash的包含放到了预编译头文件,这部分头文件exe是没有引用的
表现症状
exe可以正常运行,但是在motion中新添加的flash类实例化后无法看到成员重编,重新link,清空重编无用
换用vs2005,依然无用,但是报了一个Error: error in OMF type information 错误
解决方法
尝试将flash包含到预编译头的文件放到对外包含中,让exe也能看到这一部分问题解决
分析
VS的调试系统并不是完全开发,因此我们只能从一些表象来分析一些调试器原理及行为这个bug的原因就在 作为调试入口的exe并没有获得完全的motion里调试的信息。如果将motion作为dll加载,理论分析不会出现这种问题。dll将被作为一个单独的调试入口,需要单独加载独立的pdb。
本例中,静态库中的调试信息并没有链接到exe,因此看不到成员的任何信息
扩展
大多数的游戏或应用程序都是使用静态库来做链接,这样无论是编写还是代码安全都有所兼顾。但对于工程模块之间的互相隔离,C/C++静态库本身的毛病(CRT内存分配及静态,全局变量问题)就变得尤为严重。而使用动态链接库的接口方式也是有一部分程序这样使用的,如果为了安全或者加密,可以将动态链接库放到自己的包内,使用从内存读取dll的技术,这样安全,工程架构又清晰
相关文章推荐
- 诡异的Visual Studio 的调试bug
- 警惕VS(Visual Studio)的调试BUG漏洞
- 发现Visual Studio和Word之间的一个诡异bug
- Visual Studio调试过程中的诡异情况
- 记一次诡异的bug调试——————关于JDK1.7和JDK1.8中HashSet的hash(key)算法的区别
- Visual Studio 2008 调试运行Bug记录
- Visual Studio 2010 STL的一个bug导致内存泄露
- 改bug不能只靠蒙——调试入门
- visual studio 不能调试
- 触摸屏调试bug
- 11个强大的Visual Studio调试小技巧
- MOSS 2010: Visual Studio 2010开发体验(3)——调试代码
- 解决Visual Studio 2010/2012在调试时lock文件的方法
- Visual Studio 2008 开启被遗忘的 “同步类视图”功能、附带一个MSDN 的 bug
- 局域网使用visual studio配合iis调试手机app
- 论 BUG调试与(程序猿)初学者
- 调试EXC_ BUG
- 今天调试的一个bug,如果你懂c语言,不妨进来锻炼下眼力哦
- [No0000117]visual studio 调试WebForm 显示 HTTP Error 403.14 - Forbidden Web 服务器被配置为不列出此目录的内容。
- Visual Studio设置远程调试