Why do Queue(T) and Stack(T) not implement ICollection(T)?(为什么 Queue(T) 和 Stack(T) 没有实现 ICollection(T)?)
问题描述
在我问之前,让我得到一个明显的答案:ICollection
接口包含一个 Remove
方法来删除任意Queue<T>
和 Stack<T>
无法真正支持的元素(因为它们只能删除结束"元素).
好的,我意识到这一点.实际上,我的问题并不是关于 Queue<T>
或 Stack<T>
集合类型;相反,它是关于不为 any 本质上是 T
值集合的泛型类型实现 ICollection<T>
的设计决策.p>
这就是我觉得奇怪的地方.假设我有一个接受任意 T
集合的方法,并且出于我正在编写的代码的目的,知道集合的大小会很有用.例如(下面的代码很简单,仅供说明!):
//为简洁起见省略了参数验证.静态 IEnumerable<T>FirstHalf<T>(此 ICollection<T> 来源){诠释 i = 0;foreach(源中的 T 项){收益退货项目;if ((++i) >= (source.Count/2)){休息;}}}
现在,没有理由说这段代码不能在 Queue<T>
或 Stack<T>
上运行,只是这些类型不能实现ICollection
.当然,他们确实实现了ICollection
——我猜主要是为了Count
属性——但这会导致奇怪的优化代码如下:
//OK,这样就可以容纳那些混蛋Queue和堆栈<T>类型,//我们将只接受任何 IEnumerable<T>...静态 IEnumerable<T>FirstHalf<T>(这个 IEnumerable<T> 源){int count = CountQuickly<T>(来源);/* ... *
本文标题为:为什么 Queue(T) 和 Stack(T) 没有实现 ICollection(T)?
基础教程推荐
- 将 XML 转换为通用列表 2022-01-01
- MS Visual Studio .NET 的替代品 2022-01-01
- 有没有办法忽略 2GB 文件上传的 maxRequestLength 限制? 2022-01-01
- 为什么Flurl.Http DownloadFileAsync/Http客户端GetAsync需要 2022-09-30
- 将 Office 安装到 Windows 容器 (servercore:ltsc2019) 失败,错误代码为 17002 2022-01-01
- 如何激活MC67中的红灯 2022-01-01
- SSE 浮点算术是否可重现? 2022-01-01
- c# Math.Sqrt 实现 2022-01-01
- rabbitmq 的 REST API 2022-01-01
- 如何在 IDE 中获取 Xamarin Studio C# 输出? 2022-01-01