Курсы по программированию

Формула программиста
основатель — Волосатов Евгений Витольдович

Коллекция графов / Array vs List

  • На этом уроке мы сравним эффективность использования
    ArrayList, List<> и простого массива.
    Победителем окажется типизированная коллекция List<>.
    Очень интеренсо сравнивать эффективность,
    нам в этом поможет флагманский класс Stopwatch.
  • Дата отправки отчёта: 15 апреля
  • Задание выполнено: за 20 мин.
  • Чему научился: Сoздaл три отдeльныe фyнкции List0(), List1(), List2(), которые реализуют соответственно базовый массив, ArrayList и типизированный список List<T>.
  • Что было сложным: Ничего.
  • Комментарии: В своем случае я я выбрал такой набор операций:
    for (int i = 0; i < length; i++)
                    al.Add(length - i);
    В общем случаем я заполняю массив / коллекцию по спадению от 1 000 000 до 1. Потом вызываю метод сортировки Sort() или Array.Sort(T[] array), который работает с худшим вариантом для сортировки, потому, что ему нужно полностью переставить все элементы в обратном порядке. И измеряю время которое затрачивается на это. Результаты показывают, что  на сортировку типизированного списка List<T> затрачивается не много больше времени, чем для обычного массива (и учтите, что при добавлении элементов в список он часто увеличивал свою емкость). А коллекция ArrayList ужасно проигрывает по времени всем. Результаты представлены на 1 скриншоте.
    Во 2м случае тестировки я немного выровнял шансы и указывал при инициализации коллекций емкость в 1 000 000 элементов. Результаты тестировки представлены на 2м скриншоте.
  • Оценка видео-уроку:
Отчёт от 4467 за Коллекция графов / Array vs List


Отчёт от 4467 за Коллекция графов / Array vs List




Оцени работу

 
Сохранить страницу:

1. Евгений Витольдович
Евгений Витольдович
ответить
→  Alcatraz  # Коллекция графов / Array vs List / 2016-04-15 10:21

Классный разбор урока, молодец!


  • Отчёт оценивали:
    9263Андрей Н.+1   9567Максим+1   9286Petuško Julija+1   9288Pučko Antonina+1   1Евгений Витольдович+1   3506Алексей|BrisK|Кривицкий+1   7276Ильшат+1   6458Илья+1   4395Денис+1   9369Tautavičiūtė Anastasija+1   689Igorenzia+1   9541Сергей Валерич0   6452Lik_Kirill+1   9285Bogdaškaitė Erika+1   6958Кирилл+1   8380zhikharevav+1   459Сергей Сергеевич+1   8886Михаил Ермишин+1   9332Dima+1   6925Артём+1   2508Сергей+1  

Начинаем практику по языку C#




Чтобы стать хорошим программистом — нужно писать программы. На нашем сайте очень много практических упражнений.

После заполнения формы ты будешь подписан на рассылку «C# Вебинары и Видеоуроки», у тебя появится доступ к видеоурокам и консольным задачам.

Несколько раз в неделю тебе будут приходить письма — приглашения на вебинары, информация об акциях и скидках, полезная информация по C#.

Ты в любой момент сможешь отписаться от рассылки.
Научился: Научился сравнивать эффективность иcпользования ArrayList, List<> и простого массива.
Трудности: Сложного не было вообщем-то, если не считать код в List1(). Показал на скрине.
Очень интересно!
Научился: Научился использовать класс Stopwatch для проведения замеров времени.
Провел эксперимент с указанием количества элементов массива и коллекции при создании, так вот типизированный List работает в этом случае примерно с такой же скоростью, что и обычный массив