C# 4.0 полное руководство - 2011
Шрифт:
public virtual IList
Возвращает коллекцию типа SortedList со зна
GetValueList
чениями, хранящимися в вызывающей коллекции типа SortedList
public virtual int
Возвращает индекс ключа key. Если искомый
IndexOfKey(object key)
ключ
public virtual int
Возвращает индекс первого вхождения значения
IndexOfValue(object value)
value в вызывающей коллекции. Если искомое значение не обнаружено, возвращается значение -1
public virtual void
Устанавливает значение по индексу index рав
SetBylndex(int index, object
ным значению value
value)
public static SortedList
Возвращает синхронизированный вариант коллек
Synchronized(SortedList list)
ции типа SortedList, передаваемой в качестве параметра list
public virtual void
Устанавливает значение свойства Capacity рав
TrimToSize
ным значению свойства Count
Ключ или значение можно получить разными способами. В частности, для получения значения по указанному индексу служит метод GetBylndex , а для установки значения по указанному индексу — метод SetBylndex . Для извлечения ключа по указанному индексу вызывается метод Get Key , а для получения списка ключей по указанному индексу — метод GetKeyList . Кроме того, для получения списка всех значений из коллекции служит метод GetValueList. Для получения индекса ключа вызывается метод IndexOfKey , а для получения индекса значения — метод IndexOfValue . Безусловно, в классе SortedList также поддерживается индексатор, определяемый в интерфейсе IDictionary и позволяющий устанавливать и получать значение по заданному ключу.
В классе SortedList доступны также открытые свойства,
коллекции типа SortedList. Эти свойства определяются в интерфейсе IDictionary следующим образом.
public virtual ICollection Keys { get; } public virtual ICollection Values { get; }
Порядок следования ключей и значений отражает порядок их расположения в коллекции типа SortedList.
Аналогично коллекции типа Hashtable, пары "ключ-значение" сохраняются в коллекции типа SortedList в форме структуры типа DictionaryEntry, но, как правило, доступ к ключам и значениям осуществляется по отдельности с помощью методов и свойств, определенных в классе SortedList.
В приведенном ниже примере программы демонстрируется применение класса SortedList. Это переработанный и расширенный вариант предыдущего примера, демонстрировавшего применение класса Hashtable, вместо которого теперь используется класс SortedList. Глядя на результат выполнения этой программы, вы можете сами убедиться, что теперь список полученных значений оказывается отсортированным по заданному ключу.
// Продемонстрировать применение класса SortedList.
using System;
using System.Collections;
class SLDemo { static void Main {
// Создать отсортированный список.
SortedList si = new SortedList;
// Добавить элементы в список.
si.Add("здание", "жилое помещение");
si.Add("автомашина", "транспортное средство");
si.Add("книга", "набор печатных слов");
si.Add("яблоко", "съедобный плод");
// Добавить элементы с помощью индексатора, si["трактор"] = "сельскохозяйственная машина";
// Получить коллекцию ключей.
ICollection с = si.Keys;
// Использовать ключи для получения значений.
Console.WriteLine("Содержимое списка по индексатору."); foreach(string str in с)
Console.WriteLine(str + ": " + si[str]);
Console.WriteLine;
// Отобразить список, используя целочисленные индексы.
Console.WriteLine("Содержимое списка по целочисленным индексам."); for(int i=0; i < si.Count; i++)
Console.WriteLine(si.GetBylndex(i)) ;
Console.WriteLine ;
// Показать целочисленные индексы элементов списка.
Console.WriteLine("Целочисленные индексы элементов списка."); foreach(string str in с)