c# – 用ReaderWriterLockSLim替换ReaderWriterLock – 麻烦

由于性能问题,我已经用 ReaderWriterLockSlim替换了 ReaderWriterLock.我遇到了麻烦,这是由使用RWL时正常运行的代码引起的.

如您所见,有时MethodA(获取写锁定)调用一个方法(获取读锁定).第二种方法也是从不同的地方调用的,因此并不总是存在锁定冲突.以前,AcquiringRead锁定不会导致该问题.

除了放置“if IsRWheld”之外,有什么解决方案吗?

问题是这样的:

class Avacado
{
   readerwriterlockslim _lock = new readerwriterlockslim();

   void MethodA()
   {
      _lock.TryEnterWriteLock(-1);
         LockedList.Add(someItem)
         var result = MethodX();
      _lock.ExitWriteLock();
   }

   object MethodX()
   {
      //if called from MethodA,it will throw an exception
      _lock.TryEnterReadLock(-1);

      //...some stuff with LockedList...
      var result = LockList.something();

      _lock.ExitReadLock();

      return result;
   }
}

解决方法

从MethodA调用MethodX将其限定为锁的递归使用.
请参阅 MSDN page上针对readerwriterlockslim评论

By default,new instances of
readerwriterlockslim are created with
the LockRecursionPolicy.norecursion
flag and do not allow recursion. This
default policy is recommended for all
new development,because recursion
introduces unnecessary complications
and makes your code more prone to
deadlocks. To simplify migration from
existing projects that use Monitor or
ReaderWriterLock,you can use the
LockRecursionPolicy.SupportsRecursion flag to create instances of readerwriterlockslim that allow recursion.

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...