当我调试我的代码时,在大多数情况下,被调试的行以黄色背景突出显示(通过 Visual Studio 调试器)。这是屏幕截图:
但是,在某些情况下,调试行会以橙色背景突出显示:这是屏幕截图:
此外,有时当我按下 F10 按钮时,代码行背景从黄色变为橙色,反之亦然。这些变化背后的模式是什么?
附言 - 我想知道这是否与我的程序有两个在后台运行的独立线程这一事实有某种关系?
最佳答案
I wonder if this is somehow related to the fact that my program has two separate threads
是的,非常重要。橙色背景色是为了警告您发生了线程上下文切换,您不再调试之前查看的线程。请注意箭头上的蓝色感叹号,这是一个额外的警告。
一些示例代码使它一目了然:
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。
可能会发生以下三种情况之一,结果完全随机:
- 您进入同一线程中的下一条语句。
- 第二个线程也可能遇到断点。
- 第二个线程可能是第一个执行语句并触发调试器中断的线程。
同时观察线程调试器窗口中的黄色标记。在标记未移动的第一个项目符号中,同一线程激活了中断。背景颜色是黄色。如果标记确实移动,从而匹配最后 2 个项目符号,则背景颜色为橙色。
反复按 F10 以获得所有可能的结果。请注意,背景颜色的选择与线程窗口中当前线程是否更改完全匹配。第三个项目符号是此示例程序中最有可能的结果。
您应该尝试的下一个实验是在“线程”窗口中右键单击另一个线程并选择“卡住”。现在按 F10 始终会点击同一个线程,并且突出显示始终为黄色。当调试线程变得太困难时,您需要做的事情。
长话短说,知道您正在调试不同的线程非常重要。局部变量和堆栈跟踪可能完全不同。橙色背景和蓝色感叹号警告您。
关于c# - Debug模式下的 Visual Studio 行突出显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36982551/