Visual Studio 调试模式下的行高亮

Visual Studio line highlight in Debug mode

当我调试我的代码时,在大多数情况下,被调试的行以黄色背景突出显示(由 Visual Studio 调试器)。这是屏幕截图:

但是,在某些情况下,调试行会以橙色背景突出显示:这是屏幕截图:

此外,有时当我按下 F10 按钮时,代码行背景会从黄色变为橙色,反之亦然。这些变化背后的模式是什么?

PS - 我想知道这是否与我的程序在后台有两个单独的线程 运行 这一事实有某种关系?

I wonder if this is somehow related to the fact that my program has two separate threads

是的,非常喜欢。橙色背景色是为了警告您发生了线程上下文切换,您不再调试之前查看的线程。请注意箭头上的蓝色感叹号,这是一个额外的警告。

一些使其crystal清晰的示例代码:

using System;
using System.Threading;

class Program {
    static void Main(string[] args) {
        new Thread(Example).Start();
        new Thread(Example).Start();
        Console.ReadLine();
    }

    static void Example() {
        var rng = new Random(Thread.CurrentThread.ManagedThreadId);
        for (int loop = 0; loop < 10000; ++loop) {
            Thread.Sleep(rng.Next(0, 100));
            Thread.Sleep(rng.Next(0, 100));
            Thread.Sleep(rng.Next(0, 100));
            Thread.Sleep(rng.Next(0, 100));
            Thread.Sleep(rng.Next(0, 100));
            Thread.Sleep(rng.Next(0, 100));
            Thread.Sleep(rng.Next(0, 100));
        }
    }
}

在 Thread.Sleep() 调用之一上设置断点。按 F5 执行将在断点处停止。背景是黄色的。使用 Debug > Windows > Threads,注意当前线程上的黄色箭头。

现在按 F10。

可能会发生以下三种情况之一,结果完全随机:

  • 您进入同一线程中的下一条语句。
  • 第二个线程也可能遇到断点。
  • 第二个线程可能是第一个执行语句并触发调试器中断的线程。

同时观察线程调试器中的黄色标记 window。在标记未移动的第一个项目符号中,同一线程激活了中断。背景色为黄色。如果标记确实移动,从而匹配最后 2 个项目符号,则背景颜色为 orange.

重复按 F10 以获得所有可能的结果。请注意,背景颜色的选择与当前线程是否在 Threads window 中更改完全匹配。第三个项目符号是此示例程序中最有可能的结果。

您应该尝试的下一个实验是右键单击线程 window 中的另一个线程并选择冻结。现在按 F10 始终会点击同一个线程,并且突出显示始终为黄色。当调试线程变得太困难时,您需要做的事情。

长话短说,了解您正在调试不同的线程非常重要。局部变量和堆栈跟踪可能完全不同。橙色背景和蓝色感叹号警告你。