我想知道这是否与我的程序有两个单独的线程有关
是的,非常如此。橙色背景颜色是为了警告您发生了线程上下文切换,并且您不再调试之前查看的线程。请注意箭头上的蓝色感叹号叠加层,这是一个额外的警告。
一些示例代码使其一目了然:
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 始终会命中同一线程,并且突出显示始终为黄色。当调试线程变得太困难时您需要做的事情。
长话短说,知道您正在调试不同的线程非常重要。局部变量和堆栈跟踪可能完全不同。橙色背景和蓝色感叹号会警告您。