C# 使用async/await时的锁和信号量LIM使用差异
在使用async/await关键字访问C#中的关键部分时,通常不建议使用lock关键字或Monitor,因为在锁定关键部分的线程可能不可用的情况下,它会引入死锁 一般的方法是使用C# 使用async/await时的锁和信号量LIM使用差异,c#,multithreading,async-await,locking,C#,Multithreading,Async Await,Locking,在使用async/await关键字访问C#中的关键部分时,通常不建议使用lock关键字或Monitor,因为在锁定关键部分的线程可能不可用的情况下,它会引入死锁 一般的方法是使用信号量lim类 我的问题是,既然SemaphoreSlim(1,1)和lock在功能上是相同的,那么为什么可以使用其中一个,但另一个会引入死锁呢 这是因为SemaphoreSlim可以从任何线程释放,而lock只能由锁定它的线程“拥有”?“这是因为SemaphoreSlim可以从任何线程释放,而lock只能由锁定它的线程
信号量lim
类
我的问题是,既然SemaphoreSlim(1,1)
和lock在功能上是相同的,那么为什么可以使用其中一个,但另一个会引入死锁呢
这是因为SemaphoreSlim可以从任何线程释放,而lock只能由锁定它的线程“拥有”?“这是因为SemaphoreSlim可以从任何线程释放,而lock只能由锁定它的线程“拥有”?^Comment应该是答案。“这是因为信号量LIM可以从任何线程中释放,而锁只由锁定它的线程“拥有”吗?”^Comment应该是一个答案。