开发者

Why does ICollection<T> implement both IEnumerable<T> and IEnumerable

Why does ICollection<T> implement both IEnumerable<T> and IEnumerable?

What is the purpose of开发者_开发百科 this? How does IEnumerable benefit ICollection<T>?


IEnumerable<T> itself forces any implementation to also implement the non-generic IEnumerable. This is safe, for the same reasons that IEnumerable<out T> is covariant as of .NET 4... you can always convert the T to object for the non-generic form.

Basically this means that if you've got code which uses a parameter of type IEnumerable, you can still call it with something like List<T>.

Eric Lippert wrote a blog post recently about why collections end up implementing many interfaces, and Brad Abrams wrote a blog post back in 2005 about the specific IEnumerable<T>/IEnumerable decision.


The non-generic interface is for backward compatibility. If you write code using generics and want to pass your collection to some module written in .NET 1.0 (which doesn't have generics) you still want this to succeed, and you want the old method to be able to iterate through it.


IEnumerable<T> inherits IEnumerable so it makes sense for ICollection<T> to as well. It's just stating explicitly the inheritance that would be there anyway.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜