我正在努力使事情更简单。这是我的代码:

    If Threading.Monitor.TryEnter(syncRoot) Then
        Try
            'do something
        Finally
            Threading.Monitor.Exit(syncRoot)
        End Try
    Else
        'do something else
    End If

在噪音方面,这比ReaderWriterLock更糟糕。 我可以使用C#或VB,因此欢迎适用于其中任何一个的答案。

有帮助吗?

解决方案

使用代表?

E.g。

public bool TryEnter(object lockObject, Action work) 
{
    if (Monitor.TryEnter(lockObject)) 
    {
       try 
       {
          work();
       }
       finally 
       {
           Monitor.Exit(lockObject);
       }        
       return true;
     }

     return false;
}

其他提示

这与您的上一篇文章非常相似,我希望得到一个类似的答案。唯一显着的区别是你可能会返回“null”。如果超时失败,则从您的方法开始 - 然后是“Dispose()”未调用,您可以轻松检查值:

using(var token = GetLock(syncLock, timeout)) {
  if(token != null) { ... }
}

唯一真正的故障是您不一定要将扩展方法添加到“对象”中。 (或甚至“T,T:class”)......

Jon Skeet 过去曾对此进行过调查 - 值得一看

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top