Коллекции в C#
Массивы или коллекции?
Коллекции Список - Класс List<T>
Инициализирование списка
Ёмкость списка
Обращение к элементам списка
Длина списка
Перебор списка
Методы списка
Методы списка
Примеры
Примеры
Пример всей программы
Задание
69.88K
Category: programmingprogramming

Коллекции в C#

1. Коллекции в C#

2. Массивы или коллекции?

Работать с массивами не всегда удобно
Что, если мы заранее не знаем, сколько нам потребуется объектов?
Коллекции реализуют стандартные структуры данных, например, стек,
очередь, словарь, которые могут пригодиться для решения различных
специальных задач.

3. Коллекции Список - Класс List<T>

Коллекции
Список - Класс List<T>
Большая часть классов коллекций содержится в пространстве имен System.Collections.Generic
Класс List<T> - простейший список однотипных объектов.
Например: создание пустого списка типа string
List<string> flowers = new List<string>();
Можно сразу при создании списка инициализировать его начальными значениями.
List<string> flowers = new List<string>() { "Роза", "Тюльпан", "Орхидея", "Пион"};

4. Инициализирование списка

Можно при создании списка инициализировать его элементами из другой коллекции, например,
другого списка
List<string> MiniGarden = new List<string>() { "Ромашка", "Одуванчик" };
List<string> flowers = new List<string>(MiniGarden) { "Роза", "Тюльпан",
"Орхидея", "Пион", "Ромашка" };

5. Ёмкость списка

Если мы знаем, что список не будет превышать некоторый размер, то мы
можем передать этот размер в качестве емкости списка и избежать
дополнительных выделений памяти.
List<string> flowers = new List<string>(16);
Указание начальной емкости списка позволяет в будущем увеличить
производительность и уменьшить издержки на выделение памяти при
добавлении элементов (не обязательно).

6. Обращение к элементам списка

Как и массивы, списки поддерживают индексы, с помощью которых можно обратиться к
определенным элементам:
List<string> flowers = new List<string>() { "Роза", "Тюльпан", "Орхидея", "Пион"};
string firstPerson = flowers[0]; // получаем первый элемент
Console.WriteLine(firstPerson); // Роза
flowers[0] = “Хризантема"; // изменяем первый элемент
Console.WriteLine(flowers[0]); // Хризантема

7. Длина списка

С помощью свойства Count можно получить длину списка:
Console.WriteLine($"Сколько цветов у нас в саду? {flowers.Count}");

8. Перебор списка

C# позволяет осуществить перебор списка с помощью стандартного цикла foreach
foreach (var X in flowers) Console.WriteLine(X);
Также можно использовать другие типы циклов и в комбинации с индексами перебирать списки:
for (int i=1; i<=flowers.Count; i++) Console.WriteLine(i+". "+flowers[i-1]);

9. Методы списка

void Add(T item): добавление нового элемента в список
void AddRange(IEnumerable<T> collection): добавление в список коллекции или массива
int BinarySearch(T item): бинарный поиск элемента в списке. Если элемент найден, то метод
возвращает индекс этого элемента в коллекции. При этом список должен быть отсортирован.
void CopyTo(T[] array): копирует список в массив array
void CopyTo(int index, T[] array, int arrayIndex, int count): копирует из списка начиная с индекса
index элементы, количество которых равно count, и вставляет их в массив array начиная с индекса
arrayIndex
bool Contains(T item): возвращает true, если элемент item есть в списке
void Clear(): удаляет из списка все элементы
int IndexOf(T item): возвращает индекс первого вхождения элемента в списке
int LastIndexOf(T item): возвращает индекс последнего вхождения элемента в списке

10. Методы списка

List<T> GetRange(int index, int count): возвращает список элементов, количество которых равно count, начиная с
индекса index.
void Insert(int index, T item): вставляет элемент item в список по индексу index. Если такого индекса в списке
нет, то генерируется исключение
void InsertRange(int index, collection): вставляет коллекцию элементов collection в текущий список начиная с
индекса index. Если такого индекса в списке нет, то генерируется исключение
bool Remove(T item): удаляет элемент item из списка, и если удаление прошло успешно, то возвращает true.
Если в списке несколько одинаковых элементов, то удаляется только первый из них
void RemoveAt(int index): удаление элемента по указанному индексу index. Если такого индекса в списке нет, то
генерируется исключение
void RemoveRange(int index, int count): параметр index задает индекс, с которого надо удалить элементы, а
параметр count задает количество удаляемых элементов.
void Reverse(): изменяет порядок элементов
void Reverse(int index, int count): изменяет порядок на обратный для элементов, количество которых равно
count, начиная с индекса index
void Sort(): сортировка списка
void Sort(IComparer<T>? comparer): сортировка списка с помощью объекта comparer, который передается в
качестве параметра

11. Примеры

Console.WriteLine($"Какой еще цветок посадим? ");
flowers.Add(Console.ReadLine());
Console.WriteLine($"Растёт ли у нас одуванчик? ");
Console.WriteLine(flowers.Contains("Одуванчик"));
Console.WriteLine("Уберем один цветочек - орхидею: ");
flowers.Remove("Орхидея");

12. Примеры

Console.WriteLine("Отсортируем наш цветник ");
flowers.Sort();
Console.WriteLine("На каком месте Роза? ");
Console.WriteLine(flowers.BinarySearch("Роза")+1);

13. Пример всей программы

List<string> MiniGarden = new List<string>() { "Ромашка", "Одуванчик" };
List<string> flowers = new List<string>(MiniGarden) { "Роза", "Тюльпан", "Орхидея", "Пион", "Ромашка" };
Console.WriteLine("А в саду у нас растут цветы такие: ");
foreach (var X in flowers) Console.WriteLine(X);
Console.WriteLine($"Сколько цветов? {flowers.Count}");
Console.WriteLine($"Какой еще цветок посадим? "); flowers.Add(Console.ReadLine());
Console.WriteLine("Теперь у нас в саду: ");
for (int i=1; i<=flowers.Count; i++) Console.WriteLine(i+". "+flowers[i-1]);
Console.WriteLine($"Растёт ли у нас одуванчик? "); Console.WriteLine(flowers.Contains("Одуванчик"));
Console.WriteLine("Уберем один цветочек - орхидею: ");
flowers.Remove("Орхидея");
for (int i = 1; i <= flowers.Count; i++) Console.WriteLine(i + ". " + flowers[i - 1]);
flowers.Sort();
Console.WriteLine("Отсортируем наш цветник ");
for (int i = 1; i <= flowers.Count; i++) Console.WriteLine(i + ". " + flowers[i - 1]);
Console.WriteLine("На каком месте Роза? ");
Console.WriteLine(flowers.BinarySearch("Роза")+1);
Console.ReadLine();

14. Задание

Реализовать проект Windows Forms с использованием класса List из любой
предметной области (не цветочный сад):
Сформулировать задачу.
Реализовать ввод данных для пользователя с клавиатуры. Должна быть
возможность вносить новые значения в список, удалять значения, выводить
все значения из списка, и т.п.
Должны быть реализованы как минимум 5 методов (в том числе не
рассмотренные в примере) класса List.
на оценку 4 – методы такие же как в примере
на оценку 5 – не рассмотренные в примере методы, интересный подход к
выполнению задания
Результаты работы представить в отчёте, ответив на вопрос: какой принцип
(принципы) ООП в данном проекте явно прослеживается?
English     Русский Rules