为什么HashSet <T>没有实现IReadOnlyCollection <T>?

haz*_*zik 15 .net c# collections .net-4.5

我刚刚发现.NET Fx现在有3个有用的接口:

  1. IReadOnlyCollection<T>
  2. IReadOnlyList<T>
  3. IReadOnlyDictionary<K,V>

我有点困惑为什么HashSet<T>不实施IReadOnlyCollection<T>?有什么理由,或者微软再次忘记了套装?

UPD

经过两个小时的谷歌搜索后,我发现BCL中有很多集合,它们具有.Count属性但没有实现IReadOnlyCollection<T>接口.

UPD2

我发现这篇文章http://social.msdn.microsoft.com/Forums/en/netfxbcl/thread/b4fb991a-3f5c-4923-93d4-7cd5c004f859以及Immo Landwerth的答案他已经说过以下

除了List <>和Dictionary <>之外的其他集合是否会更新以支持这些接口?

绝对.实际上,我们所有的内置集合类型都已经实现了IReadOnlyList <>和IReadOnlyDictionary <>.这意味着,您可以直接将List,T []或Dictionary <>的实例传递给采用IReadOnly版本的API.

Jod*_*ell 15

在框架的4.5版本中,HashSet<T>没有实现IReadOnlyCollection<out T>.

这个遗漏在框架的4.6版本中得到了解决(在上述问题被提出后差不多12个月发布).

这些更正不仅限于HashSet<T>其他集合,例如Stack<T>并且Queue<T>已经获得了这些改进.

关于任何遗漏的原因的猜测是没有实际意义的.这可能是疏忽或时间压力,但坦率地说,它没什么影响.我怀疑即使我们喜欢相关的轶事,即使微软开发团队的直接输入也会有些主观.