В классе ArrayList
ArrayList
можно вставить другую коллекцию, вызвав метод InsertRange()
. Для удаления из коллекции элементов в заданных пределах достаточно вызвать метод RemoveRange()
. А для перезаписи элементов коллекции типа ArrayList
в заданных пределах элементами из другой коллекции служит метод SetRange()
. И наконец, элементы коллекции можно сортировать или искать в заданных пределах, а не во всей коллекции.По умолчанию коллекция типа ArrayList
Synchronized()
.В классе ArrayList
Capacity
, помимо свойств, определенных в интерфейсах, которые в нем реализуются.public virtual int Capacity { get; set; }
Свойство Capacity
ArrayList
. Емкость обозначает количество элементов, которые может содержать коллекция типа ArrayList
до ее вынужденного расширения. Как упоминалось выше, коллекция типа ArrayList
расширяется автоматически, и поэтому задавать ее емкость вручную необязательно. Но из соображений эффективности это иногда можно сделать, если количество элементов коллекции известно заранее. Благодаря этому исключаются издержки на выделение дополнительной памяти.С другой стороны, если требуется сократить размер базового массива коллекции типа ArrayList
Capacity
. Но это значение не должно быть меньше значения свойства Count
. Напомним, что свойство Count
определено в интерфейсе ICollection
и содержит количество объектов, хранящихся в коллекции на данный момент. Всякая попытка установить значение свойства Capacity
меньше значения свойства Count
приводит к генерированию исключения ArgumentOutOfRangeException
. Поэтому для получения такого количества элементов коллекции типа ArrayList
, которое содержится в ней на данный момент, следует установить значение свойства Capacity
равным значению свойства Count
. Для этой цели можно также вызвать метод TrimToSize()
.В приведенном ниже примере программы демонстрируется применение класса ArrayList
ArrayList
, а затем в эту коллекцию вводятся символы, после чего содержимое коллекции отображается. Некоторые элементы затем удаляются из коллекции, и ее содержимое отображается вновь. После этого в коллекцию вводятся дополнительные элементы, что вынуждает увеличить ее емкость. И наконец, содержимое элементов коллекции изменяется.// Продемонстрировать применение класса ArrayList.
using System;
using System.Collections;
class ArrayListDemo {
static void Main() {
// Создать коллекцию в виде динамического массива.
ArrayList al = new ArrayList();
Console.WriteLine("Исходное количество элементов: " + al.Count);
Console.WriteLine();
Console.WriteLine("Добавить 6 элементов");
// Добавить элементы в динамический массив.
al.Add('С');
al.Add('А');
al.Add('E');
al.Add('В');
al.Add('D');
al.Add('F') ;
Console.WriteLine("Количество элементов: " + al.Count);
// Отобразить содержимое динамического массива,
// используя индексирование массива.
Console.Write("Текущее содержимое: ");
for(int i=0; i < al.Count; i++)
Console.Write (al[i] + " ");
Console.WriteLine("\n");
Console.WriteLine("Удалить 2 элемента");
// Удалить элементы из динамического массива,
al.Remove('F');
al.Remove('A');
Console.WriteLine("Количество элементов: " + al.Count);
// Отобразить содержимое динамического массива, используя цикл foreach.
Console.Write("Содержимое: ");
foreach(char c in al)
Console.Write(c + " ");
Console.WriteLine("\n");