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

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

Коллекция графов / Hashtable

  • На этом уроке мы поработаем с Hashtable - каким именно
    образом в неё складываются значения и почему она будет
    работать, даже если хеш-функция вернёт одинаковые значения.
    Также мы увидим, что порядок элементов путается,
    а сами значения хранятся в очень хитром виде.
    В конце урока мы сделаем всё то же самое с гибридным классом.
    Самостоятельное задание: сравнить скорость работы этих коллекций.
    1 этап: создать МНОГО коллекций по 8 и по 9 элементов (ОТДЕЛЬНО).
    2 этап: создать ОДНУ коллекцию из ОГРОМНОГО количества элементов.
    Подвести итоги и в отчёте написать вывод.
  • Дата отправки отчёта: 20 сентября 2016 г.
  • Задание выполнено: за 1 час. 13 мин.
  • Чему научился: Научился работать со словарями ListDictionary, HashTable и HybrideDictionary
  • Что было сложным: Самым сложным сделать тест. Я сначала не понял задание - я создавал массив коллекций и в каждый элемент добавлял по 10 элементов - понятное дело на 100 млн записях у вылетело с exception Out of memory. Потом я начал создавать словарь и добавлять по 10 элементов и так 100 млн раз - в результате получилось.
  • Комментарии: У меня очень долго работал тест добавления 100 млн записей - пришлось сначала сократить до 10 млн, потом до 100 000 записей и то со скрина видно, что очень долго добавляются записи и примерно одинаковое время работает. А в первом случае намного быстрее - 100 млн раз по 10 записей.
  • Оценка видео-уроку:
Отчёт от 7119 за Коллекция графов / Hashtable




Оцени работу

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

5649. Максим Лапшинов
Максим Лапшинов
ответить
→  Новопашин Владимир  # Коллекция графов / Hashtable / 2016-09-20 19:17

лутше всегда с малого начинать


  • Отчёт оценивали:
    10670Сергей Соколов+1   11017Владимир Петреченко+1   8520Сергей Колупаев0   459Сергей Сергеевич+1   7645Александр Львович+1   1Евгений Волосатов+1   8065Александр0   4395Денис+1   10494Алексей В.+1   6452Кирилл Шмойлов+1   24Олюшка+1   11051Dima+1   4699Сергей Витальевич+1   4383Maryna Zhuravlova+1   4992Николай+1   4467Alcatraz+1   5649Максим Лапшинов+1   7238Константин+1   6203Николай (nick27m)+1   6391Владимир+1   10365Rita+1   10673Алексей Хонин+1  

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




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

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

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

Ты в любой момент сможешь отписаться от рассылки.
Научился: Научился самостоятельно экспериментировать и сравнивать коллекции на практике.
Скажу честно: мне лень было напрягать мозги и думать над этим, однако желание не стать посредственным программистом победило. Вот что накалякал: Я никак не мог понять, как создать много коллекций. Только потом вспомнил, что массив всегда придёт в помощь. Ну да ладно, с этим справился. Потом всё пошло отлично, но вот на скрине получилось так, что 100000 коллекций LD создаётся 200мс, а одна из 100000 элемнтов - минуту. МИНУТУ, КАРЛ! То ли я ошибся в исходнике (прикрепляю его), то ли коллекция LD быстрая только при малом кол-ве элементов? Ну а так, проэкспериментировав, можно сделать вывод, что с малым кол-вом элементов лучше LD не найти, в то же время HD-коллекции удобны при бОльшем кол-ве элементов. И ещё: я не понял третий этап, который Вы говорили на видео. Что от меня нужно? А так эксперимент понравился, спасибо за урок!
Научился: поработал с ListDictionary,Hashtable,HybridDictionary
Трудности: сложно было ждать ответ заполнения ListDictionary очень долго работает
все протестировал и так и так создания