IDictionary Interface
Represents a nongeneric collection of key/value pairs.
Namespace: System.Collections
Assembly: mscorlib (in mscorlib.dll)
The IDictionary type exposes the following members.
| Name | Description | |
|---|---|---|
![]() ![]() ![]() | Count | Gets the number of elements contained in the ICollection. (Inherited from ICollection.) |
![]() ![]() ![]() | IsFixedSize | Gets a value indicating whether the IDictionary object has a fixed size. |
![]() ![]() ![]() | IsReadOnly | Gets a value indicating whether the IDictionary object is read-only. |
![]() ![]() ![]() | IsSynchronized | Gets a value indicating whether access to the ICollection is synchronized (thread safe). (Inherited from ICollection.) |
![]() ![]() ![]() | Item | Gets or sets the element with the specified key. |
![]() ![]() ![]() | Keys | Gets an ICollection object containing the keys of the IDictionary object. |
![]() ![]() ![]() | SyncRoot | Gets an object that can be used to synchronize access to the ICollection. (Inherited from ICollection.) |
![]() ![]() ![]() | Values | Gets an ICollection object containing the values in the IDictionary object. |
| Name | Description | |
|---|---|---|
![]() ![]() ![]() | Add | Adds an element with the provided key and value to the IDictionary object. |
![]() ![]() ![]() | Clear | Removes all elements from the IDictionary object. |
![]() ![]() ![]() | Contains | Determines whether the IDictionary object contains an element with the specified key. |
![]() ![]() ![]() | CopyTo | Copies the elements of the ICollection to an Array, starting at a particular Array index. (Inherited from ICollection.) |
![]() ![]() ![]() | GetEnumerator() | Returns an IDictionaryEnumerator object for the IDictionary object. |
![]() ![]() ![]() | GetEnumerator() | Returns an enumerator that iterates through a collection. (Inherited from IEnumerable.) |
![]() ![]() ![]() | Remove | Removes the element with the specified key from the IDictionary object. |
| Name | Description | |
|---|---|---|
![]() ![]() | AsQueryable | Converts an IEnumerable to an IQueryable. (Defined by Queryable.) |
![]() ![]() ![]() | Cast<TResult> | Converts the elements of an IEnumerable to the specified type. (Defined by Enumerable.) |
![]() ![]() ![]() | OfType<TResult> | Filters the elements of an IEnumerable based on a specified type. (Defined by Enumerable.) |
The IDictionary interface is the base interface for nongeneric collections of key/value pairs. For the generic version of this interface, see System.Collections.Generic::IDictionary<TKey, TValue>.
Each element is a key/value pair stored in a DictionaryEntry object.
Each pair must have a unique key. Implementations can vary in whether they allow the key to be nullptr. The value can be nullptr and does not have to be unique. The IDictionary interface allows the contained keys and values to be enumerated, but it does not imply any particular sort order.
IDictionary implementations fall into three categories: read-only, fixed-size, variable-size. A read-only IDictionary object cannot be modified. A fixed-size IDictionary object does not allow the addition or removal of elements, but does allow the modification of existing elements. A variable-size IDictionary object allows the addition, removal, and modification of elements.
The foreach statement of the C# language (for each in Visual Basic) requires the type of each element in the collection. Since each element of the IDictionary object is a key/value pair, the element type is not the type of the key or the type of the value. Instead, the element type is DictionaryEntry. For example:
The foreach statement is a wrapper around the enumerator, which allows only reading from but not writing to the collection.
Notes to ImplementersThe implementing class must have a means to compare keys.
The following code example demonstrates how to define a simple dictionary class that implements the IDictionary interface.
Note: |
|---|
To run this example, see Building Examples That Use a Demo Method and a TextBlock Control. |
For a list of the operating systems and browsers that are supported by Silverlight, see Supported Operating Systems and Browsers.

