内容简介:当你的编写的是一个多进程的程序的时候,调试起来可能会比较困难,因为 Visual Studio 默认只会把你当前设置的启动项目的启动调试。本文将介绍几种用 Visual Studio 调试多进程程序的方法,然后给出每种方法的适用条件和优劣。在 Visual Studio 的解决方案上点击右键,属性。在公共属性节点中选择启动项目。
当你的编写的是一个多进程的程序的时候,调试起来可能会比较困难,因为 Visual Studio 默认只会把你当前设置的启动项目的启动调试。
本文将介绍几种用 Visual Studio 调试多进程程序的方法,然后给出每种方法的适用条件和优劣。
Visual Studio 多启动项目(推荐)
在 Visual Studio 的解决方案上点击右键,属性。在公共属性节点中选择启动项目。
在这里,你可以给多个项目都设置成启动项目,就像下图这样:
当然,这些项目都必须要是能够启动的才行(不一定是可执行程序)。
此方案的好处是 Visual Studio 原生支持。但此方案的使用必须满足两个前提:
- 要调试的多个进程必须是不同的项目编译出来的;
- 这些项目之间的启动顺序不能有明显的依赖关系(所以你可能需要修改你的代码使得这两个进程之间可以互相唤起)。
Microsoft Child Process Debugging Power Tool 插件(推荐)
安装和配置插件
请先安装 Microsoft Child Process Debugging Power Tool 插件。
安装插件后启动 Visual Studio,可以在 Debug -> Other Debugging Targets 中找到 Child Process Debugging Settings。
然后你可以按照下图的设置开启此项目的子进程调试:
配置项目启动选项
但是,子进程要能够调试,你还必须开启混合模式调试,开启方法请参见我的另一篇博客: 在 Visual Studio 新旧不同的 csproj 项目格式中启用混合模式调试程序(开启本机代码调试) - walterlv 。
现在,你只需要开始调试你的程序,那么你程序中启动的新的子进程都将可以自动加入调试。
例子源码和效果
现在,我们拿下面这段代码作为例子来尝试子进程的调试。下面的代码中, if
中的代码会运行在子进程中,而 else
中的代码会运行在主进程中。
using System; using System.Diagnostics; using System.Linq; namespace Walterlv.Debugging { class Program { static void Main(string[] args) { if (args.Any()) { Console.WriteLine("Walterlv child application"); Console.WriteLine(string.Join(Environment.NewLine, args)); Console.ReadLine(); } else { Console.WriteLine("Walterlv main application"); var process = new Process { StartInfo = new ProcessStartInfo(Process.GetCurrentProcess().MainModule.FileName, "--child"), }; process.Start(); process.WaitForExit(); } } } }
我们在 if
和 else
中都打上断点。正常情况下运行,只有 else
中的代码可以进断点;而如果以上子进程调试配置正确,那么两边你都可以进入断点(如下图)。
值得注意的是,只要启动了本机代码调试,就不能在程序暂停之后修改代码了(像平时调试纯托管代码那样)。
在代码中编写“附加调试器”
调用 Debugger.Launch()
可以启动一个调试器来调试此进程。于是我们可以在我们被调试的程序中写下如下代码:
#if DEBUG if (!Debugger.IsAttached) { Debugger.Launch(); } #endif
仅在 DEBUG
条件下,如果当前没有附加任何调试器,那么就启动一个新的调试器来调试它。
当存在以上代码时,运行会弹出一个对话框,用于选择调试器。
这里选择的调试器有个不太方便的地方,如果调试器已经在使用,那么就不能选择。对于我们目前的场景,我们的主进程已经在调试了,所以子进程选择调试器的时候不能再选择主进程调试所用的 Visual Studio 了,而只能选择一个新的 Visual Studio;这一点很不方便。
对于此方法,我的建议是平常不要在团队项目中使用(这会让团队中的其他人不方便)。但是由于代码简单不需要配置,所以临时使用的话还是非常建议的。
在代码中调用 Visual Studio 的 COM 组件 API
编写中……
总结
综上,虽然我给出了 4 种不同的方法,但实际上没有任何一种方法能够像我们调试单个原生托管程序那样方便。每一种方法都各有优劣,一般情况下建议你使用我标注了“推荐”的方法;不过也建议针对不同的情况采用不同的方案。
- 简单的个人项目,希望快速开始多进程/子进程调试
- 使用附加调试器
- 你有多个项目组成的多进程,并且这些进程恰好可以互相唤起,它们之间的启动顺序不影响父子进程的组成
- 使用 Visual Studio 的多启动项目
- 你只有单个项目组成的多进程,或者多个进程之间依赖于启动顺序来组成父子进程
参考资料
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- gdb调试多线程与多进程
- GDB调试多进程程序的两种方法
- Wine 开发版 3.10 发布,调试器已支持 Wow64 进程
- 进程:进程生命周期
- Python 知识巩固:通过主进程带起多个子进程实现多进程执行逻辑
- Python 中子进程与父进程
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Web 2.0 Architectures
Duane Nickull、Dion Hinchcliffe、James Governor / O'Reilly / 2009 / USD 34.99
The "Web 2.0" phenomena has become more pervasive than ever before. It is impacting the very fabric of our society and presents opportunities for those with knowledge. The individuals who understand t......一起来看看 《Web 2.0 Architectures》 这本书的介绍吧!