首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >在 Visual Studio 2019 (16.5) 中查看托管线程正在等待的锁被哪个线程占用

在 Visual Studio 2019 (16.5) 中查看托管线程正在等待的锁被哪个线程占用

作者头像
walterlv
发布2020-04-03 16:29:47
2K0
发布2020-04-03 16:29:47
举报

Visual Studio 2019 (16.5) 版本更新中带来了一项很小很难注意到却非常实用的功能,查看哪一个托管线程正在持有 .NET 对象锁。

如果你不了解这个功能如何使用,那么可以阅读本文。


更新日志

Visual Studio 的官方更新日志中对此功能的描述:

View which managed thread is holding a .NET object lock

即“查看托管线程正在持有 .NET 对象锁”。

功能入口

这个功能没有新的入口,你可以在“调用堆栈” (Call Stack) 窗口,“并行堆栈” (Parallel Stacks) 窗口,以及“线程”窗口的位置列中查看哪个托管线程正在持有 .NET 对象锁。

Call Stack

示例

现在我们就实际看一下这个功能的用法和效果。于是我写了一点下面的代码。

static void Main(string[] args)
{
    var locker = new object();

    Thread thread = new Thread(() =>
    {
        Console.WriteLine("后台线程尝试获得锁");
        lock (locker)
        {
            Console.WriteLine("后台线程成功获得锁");
        }
    })
    {
        Name = "walterlv thread",
    };

    Console.WriteLine("主线程尝试获得锁");
    Monitor.Enter(locker);
    Console.WriteLine("主线程成功获得锁");

    thread.Start();
}

在这段代码中,主线程获得锁之后直接退出,而新线程“walterlv thread”则尝试获得锁。

现在在 Visual Studio 2019 中运行这段代码,可以看到另一个线程是不可能获得锁的,于是不会输出最后那一句,其他都会输出。

锁

随后我们在 Visual Studio 中点击“全部中断”,也就是那个“暂停”图标的按钮。

全部中断
全部中断

打开调用堆栈窗口(在“调试 -> 窗口 -> 调用堆栈”),可以看到堆栈最顶端显示了正在等待锁,并且指出了线程对象。

正在等待某个线程的锁
正在等待某个线程的锁

然后在线程窗口(在“调试 -> 窗口 -> 线程“)的位置列,鼠标移上去可以看到与堆栈中相同的信息。

在线程窗口中查看
在线程窗口中查看

当然,我们的主线程实际上早已直接退出了,所以正在等待的锁将永远不会释放(除非进程退出)。

同样的信息,在并行堆栈(在“调试 -> 窗口 -> 并行堆栈”)中也能看到。

在并行堆栈中查看
在并行堆栈中查看

参考资料

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-04-02 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 更新日志
  • 功能入口
  • 示例
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档