C# 4.0 полное руководство - 2011
Шрифт:
// Добавить элементы с помощью индексатора, ht ["трактор"] = "сельскохозяйственная машина";
// Получить коллекцию ключей.
ICollection с = ht.Keys;
// Использовать ключи для получения значений, foreach(string str in с)
Console.WriteLine(str + ": " + ht[str]);
}
}
Выполнение этой программы приводит к следующему результату.
здание: жилое помещение книга: набор печатных слов трактор: сельскохозяйственная машина автомашина: транспортное средство яблоко: съедобный плод
Как следует из приведенного выше результата, пары "ключ-значение"
Класс SortedList
Класс SortedList предназначен для создания коллекции, в которой пары "ключ-значение" хранятся в порядке, отсортированном по значению ключей. В классе SortedList реализуются интерфейсы IDictionary, ICollection, IEnumerable и ICloneable.
В классе SortedList определено несколько конструкторов, включая следующие.
public SortedList public SortedList(IDictionary d) public SortedList(int initialCapacity) public SortedList(IComparer comparer)
В первом конструкторе создается пустая коллекция, первоначальная емкость которой равна нулю. Во втором конструкторе создается пустая коллекция типа SortedList, которая инициализируется элементами из коллекции d. Ее первоначальная емкость равна количеству указанных элементов. В третьем конструкторе создается пустая коллекция типа SortedList, первоначальный размер которой определяет емкость, задаваемая параметром initialCapacity. Эта емкость соответствует размеру базового массива, используемого для хранения элементов коллекции. И в четвертой форме конструктора с помощью параметра сотпрагег указывается способ, используемый для сравнения объектов по списку. В этой форме создается пустая коллекция, первоначальная емкость которой равна нулю.
При добавлении новых элементов в список емкость коллекции типа SortedList увеличивается автоматически по мере надобности. Так, если текущая емкость коллекции превышается, то она соответственно увеличивается. Преимущество указания емкости коллекции типа SortedList при ее создании заключается в снижении или полном исключении издержек на изменение размера коллекции. Разумеется, указывать емкость коллекции целесообразно лишь в том случае, если заранее известно, сколько элементов требуется хранить в ней.
В классе SortedList определяется ряд собственных методов, помимо тех, что уже объявлены в интерфейсах, которые в нем реализуются. Некоторые из наиболее часто используемых методов этого класса перечислены в табл. 25.6. Так, если требуется определить, содержится ли ключ в коллекции типа SortedList, вызывается метод Contains Key . А если требуется выяснить, хранится ли конкретное значение в коллекции типа SortedList, вызывается
Таблица 25.6. Наиболее часто используемые методы, определенные в классе SortedList
Метод
Описание
public virtual bool
Возвращает логическое значение true, если в
ContainsKey(object key)
вызывающей коллекции типа SortedList содер
жится ключ key, а иначе — логическое значение
false
Окончание табл. 25.6
Метод
Описание
public virtual bool
Возвращает логическое значение true, если в
ContainsValue(object value)
вызывающей коллекции типа SortedList со
держится значение value, а иначе — логическое значение false
public virtual object
Возвращает значение, указываемое по индексу
GetBylndex(int index)
index
public virtual
Возвращает для вызывающей коллек
IDictionaryEnumerator
ции типа SortedList перечислитель типа
GetEnumerator
IDictionaryEnumerator
public virtual object
Возвращает значение ключа, указываемое по ин
GetKey(int index)
дексу index
public virtual IList
Возвращает коллекцию типа SortedList с клю
GetKeyList
чами, хранящимися в вызывающей коллекции типа SortedList