Некоторые из перечисленных выше методов генерируют исключение NotSupportedException
, если коллекция доступна только для чтения.А поскольку интерфейс ICollection
наследует от интерфейсов IEnumerable
и IEnumerable
, то он включает в себя также обобщенную и необобщенную формы метода GetEnumerator()
.Благодаря тому что в интерфейсе ICollection
реализуется интерфейс IEnumerable
, в нем поддерживаются также методы расширения, определенные в классе Enumerable
. Несмотря на то что методы расширения предназначены главным образом для поддержки LINQ, им можно найти и другое применение, в том числе и в коллекциях.
Интерфейс IList
В интерфейсе IList
определяется такое поведение обобщенной коллекции, которое позволяет осуществлять доступ к ее элементам по индексу с отсчетом от нуля. Этот интерфейс наследует от интерфейсов IEnumerable
, IEnumerable
и ICollection
и поэтому является обобщенным вариантом необобщенного интерфейса IList
. Методы, определенные в интерфейсе IList
, перечислены в табл. 25.11. В двух из этих методов предусматривается модификация коллекции. Если же коллекция доступна только для чтения или имеет фиксированный размер, то методы Insert()
и RemoveAt()
генерируют исключение NotSupportedException
.
Таблица 25.11. Методы, определенные в интерфейсе IList
Метод -
Описание
int IndexOf(Т
item) - Возвращает индекс первого вхождения элемента item в вызывающей коллекции. Если элемент item не обнаружен, то метод возвращает значение -1void Insert(int
index, Titem) - Вставляет в вызывающую коллекцию элемент item по индексу indexvoid RemoveAt(int
index) - Удаляет из вызывающей коллекции элемент, расположенный по указанному индексу index
Кроме того, в интерфейсе IList
определяется индексатор
Т this[int index] { get; set; }
который устанавливает или возвращает значение элемента коллекции по указанному индексу index.
Интерфейс IDictionary
В интерфейсе IDictionary определяется такое поведение обобщенной коллекции, которое позволяет преобразовать уникальные ключи в соответствующие значения. Это означает, что в данном интерфейсе определяется коллекция, в которой хранятся пары "ключ-значение". Интерфейс IDictionary наследует от интерфейсов IEnumerable, IEnumerable> и ICollection> и поэтому является обобщенным вариантом необобщенного интерфейса IDictionary. Методы, объявленные в интерфейсе IDictionary, приведены в табл. 25.12. Все эти методы генерируют исключение ArgumentNullException при попытке указать пустой ключ.
Таблица 25.12. Методы, определенные в интерфейсе IDictionaryCTKey, TValue>
Метод -
Описание
void Add(TKey
key, TValuevalue) - Добавляет в вызывающую коллекцию пару “ключ-значение”, определяемую параметрами key и value. Генерирует исключение ArgumentException, если ключ key уже находится в коллекцииbool Contains(TKey
key) - Возвращает логическое значение true, если вызывающая коллекция содержит элемент key в качестве ключа, а иначе — логическое значение falsebool Remove(TKey
key) - Удаляет из коллекции элемент, ключ которого равен значению keybool TryGetValue(TKey
key, out TValuevalue) - Предпринимает попытку извлечь значение из коллекции по указанному ключу key и присвоить это значение переменной value. При удачном исходе операции возвращается логическое значение true, а иначе — логическое значение false. Если ключ key не найден, переменной value присваивается значение, выбираемое по умолчанию
Кроме того, в интерфейсе IDictionary
определены перечисленные ниже свойства.
Свойство
- Описание
ICollection Keys { get; }
Подучает коллекцию ключейICollection Values { get; }
Получает коллекцию значений
Следует иметь в виду, что ключи и значения, содержащиеся в коллекции, доступны отдельными списками с помощью свойств Keys
и Values
.И наконец, в интерфейсе IDictionary
определяется следующий индексатор.