【问题标题】:Hashtable to Dictionary<> syncroot .哈希表到 Dictionary<> syncroot 。
【发布时间】:2010-09-24 13:37:23
【问题描述】:

哈希表具有同步根属性,但通用字典没有。如果我有这样做的代码:

lock (hashtable.Syncroot)
{
....
}

如果我要删除哈希表并更改为通用字典,我该如何复制?

【问题讨论】:

    标签: c# generics dictionary hashtable


    【解决方案1】:

    如果您严格要求兼容性,那么 Bryan 是正确的。这是在字典之上维护当前语义的最佳方式。

    虽然扩展它。 SyncRoot 属性未直接添加到通用字典的原因是它是一种危险的同步方式。它只比非常危险且容易出现死锁的“lock(this)”好一点。这里有几个链接说明了为什么这是不好的。

    【讨论】:

    • 完全同意。然而,当人们回答“这很糟糕,不要这样做”时,我真的很讨厌它:)。大多数时候,人们提出一个问题,他们经常被困在一个特定的场景中,需要解决它。我会尝试就问题提供帮助,并就问题的原因以及如何避免问题提供建议。
    【解决方案2】:

    SyncRoot 背后的新思路是,它是原始设计中的一个错误。如果唯一要锁定的是字典并且它是私有的,您可以锁定它或用作同步对象的另一个对象。当您要保护的状态不仅仅是字典时,后一种技术很有用。

    // used as you would have used SyncRoot before
    object _syncLock = new object();
    Dictionary<string, int> numberMapper = new Dictionary<string, int>();
    
    // in some method...
    lock (_syncLock)
    {
        // use the dictionary here.
    }
    

    【讨论】:

    • 您是否有来源引用表明这是原始设计中的错误?
    • Brad Abrams 和 Krzysztof Cwalina(.NET 的项目经理)这样说:blogs.msdn.com/brada/archive/2003/09/28/50391.aspx
    • Jeffrey Richter 还通过 C# 在 CLR 中介绍了此设计错误。
    【解决方案3】:

    如果哈希表/字典不公开,您可以锁定字典对象本身。

    【讨论】:

      【解决方案4】:
      var dictionary = new Dictionary<int, string>();
      
      lock(((ICollection) dictionary).SyncRoot)
      {
          // ...
      }
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2011-01-01
        • 2014-08-13
        • 2023-03-31
        • 2011-04-13
        • 2011-10-27
        相关资源
        最近更新 更多