其实组里一直有人问我如何做这个,因为我们测试的产品就是一个混合了Managed Code和Unmanaged Code(Native Code)的应用程序,虽然tester可以不用去关心源码,但对于优秀的tester来说,了解你测试的应用,了解你测试的系统,是一件非常重要的事情。 当然,我们的产品规模比较大,加上C#和C++代码的混合, 不是简单的在VS里面设个断点(bp),然后F5就可以debug了。下面例出了2个可以用的方式(其实我也是从一些开发那里学来的,但只要你理解了,并勇于实践,就会变成你自己的东西) =)
(一)引自CSDN中ATFiled的介绍 http://blog.csdn.net/ATField/archive/2007/10/31/1860373.aspx
打开对非托管代码调试的功能,这个选项在项目的属性的Debug选项中存在, 打上钩即可。
如果是在Attach到一个进程的时候,需要在Attach to Process这个对话框中选择进程的类型:
缺省是自动选择,这里必须根据需求选择正确的类型。点击Select弹出Select Code Type对话框,比如,如果是调试托管和非托管混合的代码,则把Managed和Native都勾上即可。
(二)我常用的方式,虽需要事先设bp,但个人觉得比较轻量级,可以很快速的进度调试状态。
1.在cmd中cd到需要调试的应用(exe)的当前目录目录。(确保你用的是VS的tool cmd,这样做#2会方便一点!)
2. 用devenv /debugexe app.exe启动产品,vs会帮你打开一个以exe为目标的solution, 然后在其property dialog里面的DebugType选择Mixed,即表示适用于native和manage代码,然后F5直接debug。
这里要说明的一点就是,因为不是就产品源码进行debug,所以你sln里面没有整个源码的工程,你需要在#1之前打开想要转入的文件,设置bp,在debug的时候方可单步调试。
J