调试多线程程序一般有以下几种办法
1、在日志的某个地方写日志文件。
优点:不会干扰程序的执行,特别是对网络的多线程通信。
缺点:每次都需要打开日志文件以查看进程运行的信息。
2、利用断点进行调试。
优点:直观,可以直接看到运行过程的值
缺点:在多个线程设置断点,可能让程序跳来跳去,还需要额外地分出一部分精力用来理清程序的逻辑
3、利用弹出窗口来查看进程调试的信息。
优点;直观
缺点;在调试网路通信的时候,使得通信的过程产生延时,导致通信失败。
4、利用vs自带的线程窗口来调试
优点:直观,可以直接从进程图上看到哪个进程是活动进程,哪些进程处于阻塞状态。
缺点:需要结合断点调试,基本上就是断点调试的加强版
前面三种都比较基础大多数人应该已经掌握了 ,下面针对第四种再详细说明下:
比如以下示例:开了两个线程
Task.Run(() =>
{
var count = 0;
while(true)
{
Thread.Sleep(1000);
Console.WriteLine($"{count}");
count++;
}
});
Task.Run(() =>
{
var count = 0.123