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

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

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

更新日志

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

View which managed thread is holding a .NET object lock

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

功能入口

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

示例

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

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 中运行这段代码,可以看到另一个线程是不可能获得锁的,于是不会输出最后那一句,其他都会输出。

imgconvert.csdnimg.cn

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

d30f8c302b9c17d07df96b1d7f97ccc7.png

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

ad79d457b665a4ca68214679bca54a30.png

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

fc1a97bcd2c3a23ddf016516efdcc23c.png

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

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

26b9926c4b1e713b024a9ddaeafa693a.png

参考资料

我的博客会首发于 https://blog.walterlv.com/,而 CSDN 会从其中精选发布,但是一旦发布了就很少更新。

如果在博客看到有任何不懂的内容,欢迎交流。我搭建了 dotnet 职业技术学院 欢迎大家加入。

dfa5095d1230e7f7c2cc538809f2fd80.png

本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。欢迎转载、使用、重新发布,但务必保留文章署名吕毅(包含链接:https://walterlv.blog.csdn.net/),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我联系。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值