public ArrayList(int capacity)
Первый конструктор создает пустую коллекцию класса ArrayList с нулевой первоначальной емкостью. Второй конструктор создает коллекцию типа ArrayList с количеством инициализируемых элементов, которое определяется параметром с и равно первоначальной емкости массива. Третий конструктор создает коллекцию, имеющую указанную первоначальную емкость, определяемую параметром capaci ty. В данном случае емкость обозначает размер базового массива, используемого для хранения элементов коллекции. Емкость коллекции типа ArrayList может увеличиваться автоматически по мере добавления в нее элементов.
В классе ArrayList определяется ряд собственных методов, помимо тех, что уже объявлены в интерфейсах, которые в нем реализуются. Некоторые из наиболее часто используемых методов класса ArrayList перечислены в табл. 25.4. Коллекцию класса ArrayList можно отсортировать, вызвав метод Sort (). В этом случае поиск в отсортированной коллекции с помощью метода BinarySearch () становится еще более эффективным. Содержимое коллекции типа ArrayList можно также обратить, вызвав метод Reverse ().
Таблица 25.4. Наиболее часто используемые методы, определенные в классе ArrayList
Метод
Описание
public virtual void AddRange(Icollection с) public virtual int BinarySearch(object value)
Добавляет элементы из коллекции с в конец вызывающей коллекции типа ArrayList Выполняет поиск в вызывающей коллекции значения value. Возвращает индекс найденного элемента. Если искомое значение не найдено, возвращает отрицательное значение. Вызывающий список должен быть отсортирован
_ Продолжение табл. 25.4
Метод
Описание
Public virtual int
Выполняет поиск в вызывающей коллекции значения
BinarySearcii (object
value, используя для сравнения способ, определяемый
value,- Icomparer
параметром comparer. Возвращает индекс совпавше
comparer)
го элемента. Если искомое значение не найдено, возвращает отрицательное значение. Вызывающий список должен быть отсортирован
Public virtual int
Выполняет поиск в вызывающей коллекции значения
BinarySearch(int index,
value, используя для сравнения способ, определяемый
int count, object value,
параметром comparer. Поиск начинается с элемента,
IComparer comparer)
указываемого по индексу index, и включает количество элементов, определяемых параметром count. Метод возвращает индекс совпавшего элемента. Если искомое значение не найдено, метод возвращает отрицательное значение. Вызывающий список должен быть отсортирован
Public virtual void
Копирует содержимое вызывающей коллекции в мас
CopyTo(Array array)
сив array, который должен быть одномерным и совместимым по типу с элементами коллекции
Public virtual void
Копирует содержимое вызывающей коллекции в массив
CopyTo(Array array, int
array, начиная с элемента, указываемого по индексу
arraylndex)
arraylndex. Целевой массив должен быть одномерным и совместимым по типу с элементами коллекции
Public virtual void
Копирует часть вызывающей коллекции, начиная с эле
CopyTo(int index, Array
мента, указываемого по индексу index, и включая ко
array, int arraylndex,
личество элементов, определяемых параметром count,
int count)
в массив array, начиная с элемента, указываемого по индексу arraylndex. Целевой массив должен быть одномерным и совместимым по типу с элементами коллекции
Public static ArrayList
Заключает коллекцию list в оболочку типа ArrayList
FixedSize(ArrayList list)
с фиксированным размером и возвращает результат
Public virtual ArrayList
Возвращает часть вызывающей коллекции типа
GetRange(int index, int
ArrayList. Часть возвращаемой коллекции начинает
count)
ся с элемента, указываемого по индексу index, и включает количество элементов, определяемое параметром count. Возвращаемый объект ссылается на те же элементы, что и вызывающий объект
Public virtual int
Возвращает индекс первого вхождения объекта value
IndexOf(object value)
в вызывающей коллекции. Если искомый объект не обнаружен, возвращает значение -1
Public virtual void
Вставляет элементы коллекции с в вызывающую кол
InsertRange(int index,
лекцию, начиная с элемента, указываемого по индексу
ICollection c)
index
Public virtual int
Возвращает индекс последнего вхождения объекта
LastlndexOf(object value)
value в вызывающей коллекции. Если искомый объект не обнаружен, метод возвращает значение -1
Метод
Описание
Public static ArrayList
Заключает коллекцию list в оболочку типа
Readonly(ArrayList list)
ArrayList, доступную только для чтения, и возвращает результат
Public virtual void
Удаляет часть вызывающей коллекции, начиная с эле
RemoveRange(int index,
мента, указываемого по индексу index, и включая
int count)
количество элементов, определяемое параметром
count
Public virtual void
Располагает элементы вызывающей коллекции в обрат
Reverse()
ном порядке
Public virtual void
Располагает в обратном порядке часть вызывающей
Reverse(int index, int
коллекции, начиная с элемента, указываемого по индек
count)
су index, и включая количество элементов, определяемое параметром count
Public virtual void
Заменяет часть вызывающей коллекции, начиная с эле
SetRange(int index,
мента, указываемого по индексу index, элементами
ICollection c)
коллекции с
Public virtual void
Сортирует вызывающую коллекцию по нарастающей
Sort ()
Public virtual void
Сортирует вызывающую коллекцию, используя для срав
Sort(Icomparer comparer)
нения способ, определяемый параметром comparer. Если параметр comparer имеет пустое значение, то для сравнения используется способ, выбираемый по умолчанию
Public virtual void
Сортирует вызывающую коллекцию, используя для срав
Sort(int index, int
нения способ, определяемый параметром comparer.
count, Icomparer
Сортировка начинается с элемента, указываемого по
comparer)
индексу index, и включает количество элементов, определяемых параметром count. Если параметр comparer имеет пустое значение, то для сравнения используется способ, выбираемый по умолчанию
Public static ArrayList
Возвращает синхронизированный вариант коллекции
Synchronized(ArrayList
типа ArrayList, передаваемой в качестве параметра
list)
list
public virtual object[]
Возвращает массив, содержащий копии элементов вы
ToArray()
зывающего объекта
Public virtual Array
Возвращает массив, содержащий копии элементов вы
ToArray(Type type)
зывающего объекта. Тип элементов этого массива определяется параметром type
Public virtual void
Устанавливает значение свойства Capacity равным
TrimToSize()
значению свойства Count
В классе ArrayList поддерживается также ряд методов, оперирующих элементами коллекции в заданных пределах. Так, в одну коллекцию типа ArrayList можно вставить другую коллекцию, вызвав метод InsertRange (). Для удаления из коллекции элементов в заданных пределах достаточно вызвать метод RemoveRange (). А для
Перезаписи элементов коллекции типа ArrayList в заданных пределах элементами из другой коллекции служит метод Set Range (). И наконец, элементы коллекции можно сортировать или искать в заданных пределах, а не во всей коллекции.