简体   繁体   中英

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.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM