【问题标题】:Visual Studio line highlight in Debug mode调试模式下的 Visual Studio 行高亮显示
【发布时间】:2016-08-27 05:23:38
【问题描述】:

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

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

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

PS - 我想知道这是否与我的程序有两个在后台运行的独立线程有关?

【问题讨论】:

  • 它可能是橙色的,因为它是黄色(当前执行行)和红色(断点)的组合?
  • 橙色表示你有多个线程在运行。
  • 我认为这与 winforms 无关。如果您可以将 winforms-tag 替换为 VS 的版本,那就太好了,因为颜色很可能取决于版本

标签: c# visual-studio visual-studio-2010 debugging visual-studio-2012


【解决方案1】:

我想知道这是否与我的程序有两个单独的线程有关

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

一些示例代码使其一目了然:

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 始终会命中同一线程,并且突出显示始终为黄色。当调试线程变得太困难时您需要做的事情。

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

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2011-05-05
    • 2020-02-09
    • 1970-01-01
    • 2021-09-27
    • 2019-09-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多