Введение в шаблоны GRASP. Онлайн лекция

Поделиться
HTML-код
  • Опубликовано: 7 янв 2025

Комментарии • 29

  • @alexandrapersukova
    @alexandrapersukova Год назад +11

    Ребят, как вам лекция?

    • @Vitalik186
      @Vitalik186 11 месяцев назад

      супер! я аж покурив в кінці :)

  • @AlexClamp
    @AlexClamp Год назад +2

    Дякую за лекцію, займаюсь в тренажерному залі й дивлюсь 🙃

  • @SadSvit17
    @SadSvit17 Год назад

    Здравствуйте, хотел вас поблагодарить, ваша лекция помогла подготовиться к экзамену в магистратуре по дисциплине ЯЗЫК UML И ОСНОВЫ ОБЪЕКТНООРИЕНТИРОВАННОГО ПРОЕКТИРОВАНИЯ ИС

  • @MrPotapovV
    @MrPotapovV Год назад

    Дякую за цінні знання!

  • @_GreenSnake_
    @_GreenSnake_ Год назад

    Спасибо за Ваш труд

  • @itclassiq2879
    @itclassiq2879 Год назад +1

    Лекция отличная, спикер как всегда на высоте, ещё бы лекций хотя бы парочку по PoEAA

  • @ZekeFast
    @ZekeFast Год назад +1

    1:55:22 Я гадаю, що GoF дуже гарно описали повні шаблони, але у реальних системах вони змінюються та адаптуються, а іноді використовую не у повному вигляді. Дуже гарна книга на цю тему: "Рефакторінг із використанням шаблонів" від Джошуа Карієвскі ("Refactoring to Patterns" by Joshua Kerievsky).

  • @alex_nevskiy_888
    @alex_nevskiy_888 Год назад

    Спасибо, весьма понятно. Интересно было бы послушать мысли про "паттерн" "Package by features, not layers".

  • @ZekeFast
    @ZekeFast Год назад

    1:48:00 Що до великої Domain Model, то у DDD (Domain-Driven Design) вже доволі давно відомо про шаблон (aka pattern) Bounded Context, який дозволяє розподілити дуже велику й багату модель між контекстами у яких вона використовується. Модель може мати різний набір полів у залежності від контексту.
    Domain Model складна, тому що її створення лягає цілковито на розробників конкретної системи. Якщо маппінг даних, зв'язок із БД та інші функції можно якось винести до бібліотек та фреймворків та у такий спосіб зменшити вимоги до проєктувальників та розробників системи, то Domain Model є безпосередньо конкретною системою і якість її реалізації залежить від розробників системи та їх обізнаності, а також наявності часу та коштів на досягнення бажаної якості.

  • @mykola_antal
    @mykola_antal Год назад

    1:35:00 Gold фігня, якщо брати, то або Standart (для ознайомлення, подешевше), або Platinum (для повного розуміння). Gold прям для дуже специфічних умов підійде, можливо устаканити і закріпити накопичений досвід (не малий досвід)

  • @ZekeFast
    @ZekeFast Год назад

    @Sergey Nemchinskiy Я гадаю, що на сучасному етапі розвитку розробники мов програмування зрозуміли, що спадкування у стандартній формі (С++, Java, etc.) несе більше проблем ніж бенефітів. Тож у нових мовах від стандартної реалізації відмовились: Go, Rust не мають можливості стандартного спадкування між типами. Але є ідеї інтерфейсного спадкування (aka traits in Rust).
    Також треба зауважити, що стандартний ООП non-sense, це щось на кшталт AWS жаргону де віртуальний сервер зветься нодою, та інше. Але усі звикли і ніхто вже не пам'ятає, що було колись не так. Гадаю, що треба було б додати, що створення нового классу, це створення нового типу перш за все, а спадкування це не дуже гарна форма створення product типів. При цьому нормальна можливість створення Sum типів зазвичай у розповсюджених стандартних мовах програмування зазвичай відсутня, що дуже часто викликає багато проблем при моделюванні предметної області, бо у реальному житті Sum типи доволі розповсюджені. То ж не дуже обізнанні архітектори залишаються із спадкуванням та намагаються за його допомогою та ще й якоїсь матері моделювати поведінку типів-сум.
    З дуже редукованих можливостей типу-суми у Java є тільки enum, який на відміну від enum-а у тому ж Rust має більші обмеження та меньш елегантно використовується мовою.

  • @BidonNadoev
    @BidonNadoev Год назад

    1:21:04 Текст на экране про промежуточный объект, а Сергей рассказывает про интерфейс.

  • @ZekeFast
    @ZekeFast Год назад

    1:17:10 @Sergey Nemchinskiy У вас точка зору виключно бекенд-розробника. Є багато інших видів розробки де широке використання поліморфізму із динамічним диспатчем призводить до несприйнятливої вартості у продуктивності виконання програм: системне програмування, розробка ігор, баз даних, HPC, near real time та real time системи та багато інших.
    Зазвичай, але не завжди, полімормізм у мовах програмування виконано за допомогою динамічного диспатчу, що одразу вбиває можливість компілятора заглядати за такі виклики методів та інлайнити їх, що у свою чергу погіршує роботи блоку передбачення переході у ЦП та призводить до погіршення швидкості виконання програми. Але треба також зазначити, що існують можливості у мовах програмування для статичного поліморфізму із дженеріками. У цьому випадку увесь код мономорфізується для уособленого типу та усі проблеми у рантаймі зникають (але можливий code bloat).
    Про роботу JIT та його можливість інлайнити поліморфні виклики на жаль не знаю багато, може він і здатен це оптимізувати у JVM, але є багато інших мов де JIT не такий просунений чи може бути зовсім відсутній.

  • @ZekeFast
    @ZekeFast Год назад

    27:18 Linux написан на C, але є нюанс! :D Там буже часто використовується такий підхід де у структурі разом із даними є посилання на функції які треба викликати! Ось вам і класи! А може ще хтось пам'ятає, що перший "компілятор" С++ насправді був транслятором в код на С, який робив такий самий фокус! :) Тож ООП це парадигма (то як люди мислять о програмі), а писати можна й на С.
    А окрім Linux-a, ще є GTK, який теж на С написаний, але сказати, що він не об'єктноорієнтований язик не повертається, хоча ця об'єктнаорієнтовність й дуже незвично виглядає для Java розробника.

  • @ВладимирЗавидонов-и4т

    Когда будут книги? Беру. Две.

  • @QimAliq
    @QimAliq Год назад +3

    тээк ну насчет однопоточности UI Немчинский зря на человека наезжал! UI реально выполняется в одном потоке обычно, а примеры, которые приводил Немчинский, относятся к асинхонности / очереди (помпе) сообщений / реакции на события (или как оно там правильно называется?). в браузере скрипт вообще всегда в одном потоке выполняется, насколько я знаю, для скрипта в принципе многопоточность невозможна

    • @ZekeFast
      @ZekeFast Год назад +2

      Також Node.js у більшості випадків працює у одному потоці, але асінхронно. Також є можливість пускати її з декількома воркерам та різними потоками. Щей зараз, якщо додаток виконується на кубері (Kubernetes), то часто конфігурують лише один потік на под (pod) із котейнером.

  • @Sprint-n3n
    @Sprint-n3n Год назад

    Fine

  • @seoonlyRU
    @seoonlyRU Год назад +1

    лайк от СЕООНЛИ

  • @oleksiymusiyezdov5040
    @oleksiymusiyezdov5040 Год назад +1

    Cohesion - однородность (как вариант).

  • @speedyjet4508
    @speedyjet4508 11 месяцев назад

    😂😂😂какой-то козёл, который пришёл снаружи это однозначно 5!

  • @savchuk-ruslan
    @savchuk-ruslan Год назад

    Стосовно термінів для coupling cohesion. Бачив переклад "связанность" і "связность" мені більше сподобалось

  • @АлексейБаранов-з1ц

    Сергей, я нашёл отсылку на Вас в мультике 95 квартала (младший брат)
    ruclips.net/video/vpqYD7sRV0I/видео.html

  • @errandir
    @errandir Год назад

    А почему бы «cohesion» не перевести просто как «когезия» и начать использовать именно его? Вполне себе нормальный термин, и суть отражает. Ну и что, что там ранее напереводили.

  • @анатолийАнатольевич-ю4ч

    Вообще не зашло, пробовал смотреть три ваших видео... Вы хотя бы примеры меняли бы...

  • @eligolin9947
    @eligolin9947 Год назад

    Ха ха... весь IoC это полное противоречия этому так сказать Creator принципу. 😂

  • @aleksandrbeloushkin7971
    @aleksandrbeloushkin7971 Год назад

    Зачем нужны справочники, если есть ChatGPT)