Non-Generic Collections to be Removed from Silverlight [Inbar Gazit]
Those of you who are already using Silverlight 1.1 Alpha may have seen that the familiar non-generic collections were all marked as obsolete. This includes almost everything under the System.Collections namespace. You shouldn’t be too surprised. We’ve been telling you for a while that you should not be using these anymore and to instead use the generic collections in the System.Collections.Generic namespace. See the following blog post for more details on how and why to convert your non-generic collections.
While you can technically use obsolete types and only get warnings, we’re completely removing these types from Silverlight so we seriously advise you against using them.
The following types will be completely removed:
- ArrayList
- BitArray
- CaseInsensitiveComparer
- CaseInsensitiveHashCodeProvider
- CollectionBase
- Comparer
- CompatibleComparer
- DictionaryBase
- EmptyReadOnlyDictionaryInternal
- Hashtable
- IHashCodeProvider
- KeyValuePairs
- ListDictionaryInternal
- Queue
- ReadOnlyCollectionBase
- SortedList
- Stack
On the other hand we decided to keep most of the non-generic interfaces (including those who were previously marked as obsolete):
- IEnumerator
- IEnumerable
- ICollection
- IComparer
- IDictionary
- IDictionaryEnumerator
- DictionaryEntry
- IEqualityComparer
- IList
The non-generic collection interfaces are required for scenarios where you don’t know the type of T. Consider databinding as an example. Databinding works using non-generic methods today, and can deal with List<T> only because it implements the non-generic IList. There’s no easy way to get an arbitrary T in a non-generic method & manipulate it efficiently. While it may be possible to use Reflection to extract the T and use the type in a very late-bound fashion, this approach incurs a significant performance hit. We must continue to ship our non-generic collection interfaces.
Three other generic types were also removed. Queue<T>, Stack<T> and LinkedList<T> were removed from Silverlight. In this case it wasn’t because they were non-generic but because they are not considered to be part of the core set of types that we deemed essential to be provided with Silverlight. Remember that Silverlight is a very small download and should only include the smallest set of APIs that will allow for useful development. It’s very simple to implement Queue<T> and Stack<T> using List<T> and LinkedList<T> is just a different implementation of List<T> with different performance characteristics and so it’s not an essential part of our core collections group.
Expect to see these changes in a future preview release of Silverlight 1.1. Keep checking out our blog for the announcement about when and where...
Comments
Anonymous
June 26, 2007
Whats the efficient, generic version of BitArray?Anonymous
June 26, 2007
Collection classes like ArrayList, SortedList, Stack and Hashtable will shortly be obsoleted (i.e. theAnonymous
June 26, 2007
Michael, You can use and Array or a List<Boolean> to get the functionality of a BitArray. However, if by efficient you mean that we don't use unnecessary bits to store the data - that solution is not efficient. For Silverlight we decided that the need for BitArray is minimal and the workaround are decent enough. In the big framework you can still use BitArray if you have a need for efficiency or use generics if you don't.Anonymous
June 26, 2007
Michael, If you're not using more than 32 bits, you might be able to use BitVector32.Anonymous
June 26, 2007
Silverlight is getting smaller and smaller...Anonymous
June 26, 2007
Silverlight is getting smaller and smaller...Anonymous
June 26, 2007
silverlight: base class changes comingAnonymous
June 26, 2007
The BCL Team have confirmed via their blog that they will be removing some of the BCL types from SilverlightAnonymous
June 27, 2007
- Are there any plans to obsolete non-generic collections in future versions of .NET Framework?
- Is Silverlight a branch of .net framework code or you have a single source code tree?
- Anonymous
June 28, 2007
lexp,
- Not at this point. Check the blog often to be updated on our latest plans.
- We have a single source code and we build it separately for Silverlight from the big framework so that we only have parts of it in Silverlight. The rest should be the same in both frameworks for the most part.
Anonymous
June 28, 2007
Luckily the interfaces are still left in. They were marked obsolete, but I had some binding scenariousAnonymous
June 28, 2007
Can you make it so List<T> is completely implemented? The two I miss are: List<T> CTOR that takes an IEnumerable and the List<T> AddRange. If not already there, it would be nice to have an Observable<T> collection as well so we can know when the collection changed through an event.Anonymous
June 29, 2007
Jfo, I'm not sure why you think these are not implemented in Silverlight but this is not the case. List<T> has the same constructors as in 2.0/3.5 and also has the AddRange method implemented. Please take a second look to make sure. As for Observable<T>, that's an interesting idea...Anonymous
June 29, 2007
The comment has been removedAnonymous
July 04, 2007
Silverlight 1.1ではGenericでないCollectionはなくなるそうな。Anonymous
July 07, 2007
According to Inbar Gazit almost all of the System.Collection classes (and Queue<T>, Stack<T>Anonymous
July 19, 2007
Silverlight 1.1の基本クラス ライブラリにおける非ジェネリック系のCollectionについて Alpha版で調査をなされていらっしゃるお客さまも多いのではと思いますが、Silverlightのランタイムにおいて非ジェネリック系のコレクションAnonymous
July 19, 2007
Alpha版で調査をなされていらっしゃるお客さまも多いのではと思いますが、Silverlightのランタイムにおいて非ジェネリック系のコレクション クラスを取り除く予定でございます。また、ジェネリックのコレクションAnonymous
February 07, 2008
In Silverlight 1.1 the non-generic collections were marked obsolete. We have announced that the non-genericAnonymous
February 07, 2008
In Silverlight 1.1 the non-generic collections were marked obsolete. We have announced that the non-genericAnonymous
February 19, 2008
In Silverlight 1.1 the non-generic collections were marked obsolete. We have announced that the non-genericAnonymous
June 28, 2008
The comment has been removed