Создать коллекцию в виде динамического массива.
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");
Console.WriteLine("Добавить еще 20 элементов");
Добавить количество элементов, достаточное для
Принудительного расширения массива,
for (int i=0; i < 20; i++)
al.Add((char)('a' + i));
Console.WriteLine("Текущая емкость: " + al.Capacity);
Console.WriteLine("Количество элементов после добавления 20 новых: " + al.Count);
Console.Write("Содержимое: ");
Foreach(char c in al)
Console.Write(c + " ");
Console.WriteLine("\n");
Изменить содержимое динамического массива,
Используя индексирование массива.
Console.WriteLine("Изменить три первых элемента");
al[0] = 'X';
|
|
al[1] = 'Y';
al[2] = 'Z';
Console.Write("Содержимое: ");
Foreach(char c in al)
Console.Write (c + " ");
Console.WriteLine();
}
}
Вот к какому результату приводит выполнение этой программы.
Исходное количество элементов: 0
Добавить 6 элементов
Количество элементов: 6
Текущее содержимое: С А E В D F
Удалить 2 элемента
Количество элементов: 5
Содержимое: С А E В D
Добавить еще 20 элементов
Текущая емкость: 32
Количество элементов после добавления 20 новых: 25
Содержимое: С А E В D a b c d e f g h i j k l m n o p q r s t
Изменить три первых элемента
Содержимое: X Y Z В D a b c d e f g h i j k l m n o p q r s t
Для продолжения нажмите любую клавишу . . .
Сортировка и поиск в коллекции типа ArrayList
Коллекцию типа ArrayList можно отсортировать с помощью метода Sort(). В этом случае поиск в отсортированной коллекции с помощью метода BinarySearch() становится еще более эффективным. Применение обоих методов демонстрируется в приведенном ниже примере программы.
// Отсортировать коллекцию типа ArrayList и осуществить в ней поиск.
using System;
using System.Collections;
class SortSearchDemo {
static void Main() {
// Создать коллекцию в виде динамического массива.
|
|
ArrayList al = new ArrayList();
// Добавить элементы в динамический массив.
al.Add(55);
al.Add(43) ;
al.Add(-4);
al.Add(88);
al.Add(3);
al.Add(19) ;
Console.Write("Исходное содержимое: ");
foreach(int i in al)
Console.Write (i + " ");
Console.WriteLine ("\n");
// Отсортировать динамический массив,
al.Sort();
// Отобразить содержимое динамического массива, используя цикл foreach.
Console.Write ("Содержимое после сортировки: ");
foreach (int i in al)
Console.Write (i + " ");
Console.WriteLine ("\n");
Console.WriteLine("Индекс элемента 43: " + al.BinarySearch (43));
}
}
Ниже приведен результат выполнения этой программы.
Исходное содержимое: 55 43 -4 88 3 19
Содержимое после сортировки: -4 3 19 43 55 88
Индекс элемента 43: 3
В одной и той же коллекции типа ArrayList могут храниться объекты любого типа. Тем не менее во время сортировки и поиска в ней эти объекты приходится сравнивать. Так, если бы список объектов в приведенном выше примере программы содержал символьную строку, то их сравнение привело бы к исключительной ситуации. Впрочем, для сравнения символьных строк и целых чисел можно создать специальные методы. О таких методах сравнения речь пойдет далее в этой главе.
|
|
Получение массива из коллекции типа ArrayList
В работе с коллекцией типа ArrayList иногда требуется получить из ее содержимого обычный массив. Этой цели служит метод ТоАггау(). Для преобразования коллекции в массив имеется несколько причин. Две из них таковы: потребность в ускорении обработки при выполнении некоторых операций и необходимость передавать массив методу, который не перегружается, чтобы принять коллекцию. Но независимо от конкретной причины коллекция типа ArrayList преобразуется в обычный массив довольно просто, как показано в приведенном ниже примере программы.
// Преобразовать коллекцию типа ArrayList в обычный массив.
using System;
using System.Collections;
class ArrayListToArray {
static void Main() {
ArrayList al = new ArrayList();
Дата добавления: 2019-02-12; просмотров: 261; Мы поможем в написании вашей работы! |
Мы поможем в написании ваших работ!