C#多线程调试

概要

这篇文章主要分享多线程部分调试技巧,在日常的开发工作中会经常遇到多线程调试的需要。在我们调试的过程中会出现断点的焦点在多个线程之间“反复横跳”根本无法集中跟踪某一个线程的操作链路。那么今天我们来看看如何调试操作。如果有其它需要的可以参考下面微软官方的文档地址。

a284705f2ca6eac7f026317911b4a618.png

  • 参考文献:https://docs.microsoft.com/zh-cn/visualstudio/debugger/get-started-debugging-multithreaded-apps?view=vs-2022

  • 工具:VisualStudio 2022

  • 框架:.NET5

  • 语言:C#

  • 程序:控制台应用

详细内容

开始调试之前我们先需要明白一个概念--“调试条件”。

77ffe7c0b97dcfc444b62c747a3a9658.png

调试条件编写,下图的红圈里就是编写条件的文本框。文本框里的内容和写C#代码中if判断里的条件没有任何区别。同时还能在里面编写方法。

157fd98fc7e0f6651a4415d9a5cfcd30.png

---分割线--

eb7dd404101f044f7ad5cb653b97eb36.png

当条件文本框失去焦点之后自动保存。

004cbcec838d5846caa86730f62bca61.png

调试技巧1:

  • 1.编写测试代码

internal class Program
    {
        static void Main(string[] args)
        {
            Task[] task = new Task[6];
            for (int i = 0; i < task.Length; i++)
            {
                task[i] = Task.Run(Do);
            }
            Task.WaitAll(task);
        }

        private static void Do() 
        {
            int x = Thread.CurrentThread.ManagedThreadId;
            while (true)
            {
                Console.WriteLine(DateTime.Now);
            }
        }
    }
  • 2.打开线程监控窗口(需debug启动之后再点开“调试”选项)

208580bb757a419d7021d501e4baed7f.png

68adeedd978202f3d432d84c2278a20b.png

  • 3.设置断点

904312234bfabb045246db1cc746f58a.png

  • 4.设置你需要查看的线程id

4a51b35caf946cecc2ae9499c758e281.png

编写调试条件

71d6a3f47bbf9986132653f2c19b9e31.png

F10开始调试

eb7e8f92087b657cec730a659a427e7e.png

调试技巧2:

  • 1.编写测试代码

internal class Program
    {
        static void Main(string[] args)
        {
            Task[] task = new Task[6];
            for (int i = 0; i < task.Length; i++)
            {
                task[i] = Task.Run(Do);
            }
            Task.WaitAll(task);
        }

        private static void Do() 
        {
            int x = Thread.CurrentThread.ManagedThreadId;
            //循环调试
            for (int i = 0; i < 100; i++)
            {
                Console.WriteLine(i);
            }
        }
    }

当遇到循环时,也可以编写调试条件。这样我们就不用一直按F10按50次了。

983f210f7b915a7f68a90efab8856565.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值