Clean Architecture (чистая архитектура, все для проекта любого размера, принципы, мышление)

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

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

  • @aspdof-wy7nj
    @aspdof-wy7nj 3 месяца назад +303

    если сейчас в 11 ночи начну смотреть то завтра к дейлику буду 10x разработчиком. спасибо!

    • @MentorOfMentors
      @MentorOfMentors 3 месяца назад +6

      5 дней уже прошло, получилось?

    • @NikolayVerhovcev
      @NikolayVerhovcev 3 месяца назад

      @@MentorOfMentorsвидимо нет, уволили

    • @nick-ei2og
      @nick-ei2og 2 месяца назад +11

      вмер

    • @ivanfilippov2917
      @ivanfilippov2917 2 месяца назад +1

      Я только начал, а ты то закончил?

    • @ayratasfandyiar7120
      @ayratasfandyiar7120 2 месяца назад

      Что в итоге?

  • @link_onion
    @link_onion 2 месяца назад +38

    Посмотрел 2 часа, что скажу. Подача материала раскрывается последовательно, всё поделено на таймкоды. Каждый принцип SOLID раскрывается последовательно и что самое отличительное - это универсальность материала под различные языки программирования. То есть это, своего рода, технический альманах, к которму можно переодически возвращаться для того, чтобы освежить память по различным стратегиям проектирования. Кароче полезность материала прямо пропорциональна крутости шрифта помноженного на бесконечность в квадрате. Благодарю автора за усилия, и за таймкоды отдельно thankful.

  • @superrekeng
    @superrekeng 3 месяца назад +109

    Забавно слышать в первые 30 секунд 12 часового видео "упрощать и декомпозировать большие системы"

    • @DmitriNesterov
      @DmitriNesterov 3 месяца назад +2

      Ух ты ж! Я было подумал, что час двадцать %) Надеялся за пару раз посмотреть 😊 Что ж, придётся поднапрячься и за недельку осилить.

    • @dm.hol.3624
      @dm.hol.3624 2 месяца назад +7

      @@DmitriNesterov Смотрю уже 3 часа. Я middle разработчик. Это переворот в сознании: обрывки знаний укладывает в голове. Напрягитесь, оно того стоит.

    • @armm6437
      @armm6437 2 месяца назад

      В том то и парадокс))

  • @artykrivi9199
    @artykrivi9199 3 месяца назад +38

    Человек, который объясняет какое-либо направление программирования с визуализацией в excaildraw по дефолту делает все верно! Труд монументальный)

  • @ddktst
    @ddktst Месяц назад +3

    люди не чувствую гармонию в информационных системах и это видео просто подарок тем кто пытается разобраться. спасибо большое

  • @JIucmuk
    @JIucmuk 2 месяца назад +15

    Не передать того восторга, который испытал я совместно со своим одногруппником при просмотре данного видео, хотя я скорее назвал бы это полноценным лекционным материалом. Автор четко ответил на все вопросы к теории архитектуры, которые могли быть у студента 4 курса. Такого концентрированного материала не хватало мне на протяжении последнего года и неоднократных попыток самому разобраться в чистой архитектуре.
    Хочется отметить теорию интерфейсов, которую тщательно объяснял автор. Буквально открытие истинного взгляда на интерфейсы, как на контракты между функциональными модулями, позволило легко воспринять все последующие виды архитектур. Также это позволило лучше определить связь между разработкой архитектуры ПО в контексте программирования и моделированием информационной системы в контексте бизнес анализа.
    Ни могу не отметить, верно поданную концепцию функционального программирования и то, какое отношение она имеет к разработке и проектированию ПО любой сложности. Это, прямо говоря, заставило переосмыслить прошедший курс функционального программирования на Лиспе, где упор делался на синтаксис языка, нежели ценностях и возможностях данного подхода.
    Еще раз скажу большое спасибо за этот головокружительный материал. Хотелось бы увидеть меньше повторов ( хотя для формата лекций, это только плюс ) и больше Практического материала или ссылок на хорошие примеры в открытом доступе для самостоятельного изучения.

    • @koduryem
      @koduryem  2 месяца назад +1

      Все таки я очень рад, что есть люди, которые в полной мере поняли меня, а не смотрели на речь или сравнивали с конкретными определениями. Спасибо большое

    • @JIucmuk
      @JIucmuk 2 месяца назад

      @@koduryem Вам спасибо конечно же. Сейчас посмотрел комментарии, не вижу причин как-то придираться к конкретным сравнениями или речи, когда важная сама суть и то как она усваивается. Вы на протяжении всего ролика повторяете некоторые вещи многократно и с разных ракурсов, и это хорошо. С таким подходом можно понять суть вещи и идею, которую хочет преподнести автор.
      В процессе обучения в вузе я много раз видел, преподавателей, которые пытаются мимолетно схватится за определения не раскрывая суть вопроса или раскрывая его так, что потом из 100 студентов дай бог поймет 3-4, но при этом уже пытаться перейти на менее существенный вопрос из-за чего в голове у студентов каша, а знаний нет.

  • @brojeg
    @brojeg 3 месяца назад +60

    Под этим видео нужно написать два комментария. Один до того как начал смотреть, а другое когда закончишь.

    • @АлексейСемцов
      @АлексейСемцов 3 месяца назад +13

      Включил, начал смотреть, поел, поспал, снова поел, вернулся к ноуту, а там всё ещё вступление... (

  • @mystiquewind4571
    @mystiquewind4571 2 месяца назад +7

    Чтобы посмотреть это видео у меня ушло две недели) Это хорошо структурированные практические знания по архитектуре. Именно то, что было нужно. Моё почтение автору за то, что всё подано в одном видео, с самурайским терпением.
    Возможно, кого-то испугает 12 часов архитектуры. Интересно, а сколько времени у вас ушло бы чтобы изучить это на собственном опыте а затем записать видеоурок? Тысячи часов совершения ошибок и нахождения решений ужаты в 12. Это подарок всему миру разработчиков.

    • @koduryem
      @koduryem  2 месяца назад

      Большое спасибо :)

  • @andreidetenkov
    @andreidetenkov 3 месяца назад +8

    Пожалуйста, не забрасывай канал. Чувак, ты крутой! Круче только титановые яйца, да и то не факт )

  • @rocotbrent
    @rocotbrent 2 месяца назад +3

    Это просто праздник какой-то🎉. Повезло, что кто-то или что-то сподвигло автора на труд его.

  • @SergeyPryada
    @SergeyPryada 2 месяца назад +2

    В процессе просмотра некоторые фрагменты воспринимались как фильм ужаса с флешбеками из прошлого
    Бывало и так, что реализуешь интерфейс «на будущее», а при следующем рефакторинге его полностью выпиливаешь...
    Огромный труд, спасибо за видео, под него очень хорошо думается о своей кодовой базе.

  • @ВладОся-з7ь
    @ВладОся-з7ь 3 месяца назад +3

    Как давно я ждал что-то подобное . Спасбо за труд)
    Буду наверно дополнять свой комментарий с просмотром.
    Половину уже посмотрел и хочу сказать что видос полезен на 1000% , такой материал даже на eng языке не найдёшь. Честно я очень довно искал материал по поводу чистого кода. И книжка Стива Макконнелла - Совершенный код не дала мне той базы которая есть тут. Хочу ещё раз сказать автору спасибо за информацию которая поможет стать професионалом в IT

  • @Валерий-н6м6г
    @Валерий-н6м6г Месяц назад +2

    Сразу лайк не глядя это видео. Но посмотрев монументальный гад - "Как решать задачи на Leetcode(+полный гайд, работа..." могу с уверенностью сказать, что и здесь будет полных 11 часов годноты!!! Артем, ты лучший! )

  • @leniumso8578
    @leniumso8578 3 месяца назад +44

    Господа, пишите красивый, читаемый и понятный другим людям код! Чтобы руководителю было проще вас заменить))

    • @mobilitymoon5232
      @mobilitymoon5232 3 месяца назад +11

      Да лучше писать лапшой и потом самому уволиться.

    • @toohit
      @toohit 2 месяца назад

      ​@@mobilitymoon5232Этим ты помогаешь комьюнити, ведь наймут другого с +30% зарплатой и у него будет работы много переписать все с году сказав что технический долг не подъемный) и так по кругу)

    • @Vedariy
      @Vedariy 2 месяца назад +4

      думаю если вы будете писать красивый и читаемый код, то руководитель сделает всё чтобы вы не ушли. Потому что другие будут писать нечитаемый код.

    • @lindx2533
      @lindx2533 2 месяца назад

      Быть или не быть)

  • @МаксимМалофеев-п3ы
    @МаксимМалофеев-п3ы 3 месяца назад +2

    Вот это подарок, теперь знаю, чем буду заниматься ближайшие выходные, спасибо Вам огромное!

  • @armanbekmuratov1772
    @armanbekmuratov1772 3 месяца назад +3

    спасибо большое за такой огромный труд, даже сложно представить сколько усилий и усердий нужно приложить, чтобы сделать такое полезное видео!

  • @antonmahagon6299
    @antonmahagon6299 2 месяца назад

    ура! я наконец всё посмотрел, аж 20 дней ушло))
    Лучшее что я видел про архитектуру, спасибо!

  • @izolius5157
    @izolius5157 29 дней назад +1

    Несколько недель и я осилил! Спасибо, очень полезно с точки зрения именно паттернов мышления

  • @alexandr6055
    @alexandr6055 2 месяца назад +3

    И так я досмотрел видео курс честно до конца, без пропусков. Во-первых скажу большое спасибо автору за проделанную отличную работу! Лично для меня видео крайне полезное, конечно многое из паттернов и принципов я знал, но благодаря этому видео я как бы закрыл какие-то пробелы что-ли или посмотрел на что-то с другой стороны. Так же полезны советы в области инкапсуляций с выводами апи, чистых функций, абстракций/дженериков и конечно low coupling & high cohesion.
    Для тех кто не смотрел крайне рекомендую, будет полезно.

    • @koduryem
      @koduryem  2 месяца назад

      Спасибо большое 🙏

  • @bearbrown7668
    @bearbrown7668 19 дней назад +3

    Не знаю написал ли кто, в целом можно сказать что это описание Clean Code здорового человека)
    За почти 15 лет в IT в 95% сталкивался именно с black/white подходом)

    • @koduryem
      @koduryem  9 дней назад

      Спасибо большое)

  • @vadymurupa4187
    @vadymurupa4187 9 дней назад

    Очень хороший ру яз материал, приятно удивлён, спасибо.

  • @ИннокентийВознесенский

    Спасибо вам за ваш труд❤

  • @AntonGavrilov-tg3oj
    @AntonGavrilov-tg3oj 3 месяца назад

    Инфа просто на вес золота! Это прям то что надо! Пушка-бомба, всё просто, понятно и по сути. Огромная работа проделала. Чел, мега-респект тебе. Лайк и подписка однозначно!

    • @koduryem
      @koduryem  3 месяца назад

      Спасибо большое :)

  • @ginhop1057
    @ginhop1057 2 месяца назад +2

    Огромное спасибо за проделанную работу, рили очень круто, скачал себе на комп, буду показывать внукам)

  • @Aczamaz
    @Aczamaz 3 месяца назад +3

    11 часов годноты, это я смотрю и на тебя я подписываюсь!

  • @DreamHome_01
    @DreamHome_01 3 месяца назад +1

    Ого, очень мощное видео. Посмотрел уже 3 часа, очень хорошо и увлекательно рассказываете. Презентация так вообще стильная и приятная глазу.
    Огромное спасибо за труды

  • @VitaliyMB
    @VitaliyMB 2 месяца назад +1

    Спасибо тебе за это! Просто спасибо!

  • @enj0yer76
    @enj0yer76 3 месяца назад +12

    Я как включил, услышал:"В этом видео мы поговорим про чистую архитектуру и чистый код", сразу подумал, что-то тут не чисто... очень испугался 12часового видоса ) ну будем смотреть 😅

  • @vitali5615
    @vitali5615 3 месяца назад +1

    Спасибо! Очень полезно было.
    Я бы еще посоветовал сделать пример проекта с применением ports/adapters архитектуры. Ты абсолютно правильно сказал - что многие слышали (не слышали) про это и что это такое вообще - лучше писать как знаю).
    Это теория, и если внимательно (вдумчиво) посмотреть, то можно сказать - да ок понятно.
    Вот на 100% уверен, что если кто решит - а давай я сяду и попробую это сделать на простом проекте - не получится. И чел забьет, и будет опять - лучше писать как знаю.
    Такой материал ты выдал классный, надо еще пример дать чтоб зря не было)
    Еще бы и на двух разных языках ООП (Java например) и не ООП (JS на пример) - это две разные песни будут.
    Это просто мой feedback, мысли. Очень часто с этим сталкиваюсь, когда люди с опытом не могут написать используя эти подходы (SOLID, Clean Architecture), пытаешься что-то обьяснить - говорят что сложно, лучше как всегда, потому что придут новые люди и не поймут)
    Вообщем спасибо за видос, за передачу опыта!

  • @MrKelebras
    @MrKelebras 2 месяца назад

    Спасибо за работу! Прикольное видео, улучшил структуру и дополнил свой склерозник. Это первое видео на данном канале и сразу такой вызов)

    • @koduryem
      @koduryem  2 месяца назад

      Спасибо) для меня оно тоже что-то вроде альманаха, чтобы быстро можно было вспомнить основные практические принципы и не утонуть в тонне теоретики :)

  • @khritavarman9832
    @khritavarman9832 2 месяца назад

    Офигеть, 11 сурено-минут. Большое спасибо

  • @artemtupchienko3769
    @artemtupchienko3769 3 месяца назад

    Огромный труда, великолепное видео, спасибо большое автору за проделанную работу!

  • @cheshiressmile1404
    @cheshiressmile1404 3 месяца назад +2

    крутое видео, долго искал что-то по архитектуре и вот нашлось! Типо я чувак с 1 г комм. опыта на js и мне прям вкатило. Про солид 90% понятно, типо я уже 3 часа просмотрел, прям кайф, ещё и с картинками прям шик. За видос спасибо. Двигаем дальше - ещё 8 ч осталось (уже 6)

    • @koduryem
      @koduryem  2 месяца назад

      Спасибо)

  • @AlexanderMerzlikin
    @AlexanderMerzlikin 2 месяца назад +14

    Человек снял видео за 4 футболки!

    • @arturogatti914
      @arturogatti914 2 месяца назад +1

      То чуство когда хотел посмотреть все видео в течении недели, но все ещё на находишься на 1 футболке спустя 3 недели...

    • @AlexanderMerzlikin
      @AlexanderMerzlikin 2 месяца назад

      @@arturogatti914 Для такого видео - это нормально, если вдумчиво смотреть

  • @azaytsev87
    @azaytsev87 3 месяца назад

    Очень фундаментально. Очень интересно. Всё по делу и без лишней воды. Зашло. Лайк, подписка на канал и комментарий для продвижения.👍👍👍

  • @denchurikov210
    @denchurikov210 3 месяца назад +1

    Шикарный контент, продолжай в том же духе👍

  • @arsenask13
    @arsenask13 2 месяца назад +1

    спасибо. Я пока ничего не понимаю поэтому оценю оформление - оно топовое )

  • @heybeachMIN
    @heybeachMIN 3 месяца назад +2

    Не, ну за недельку я думаю смогу посмотреть) лайк не глядя

  • @link_onion
    @link_onion 3 месяца назад +1

    11 часов. афигеть. насколько же чиста эта архитектура? напишу коммент и скажу что со мной стало по оканчанию просмотра видоса

  • @ly2960
    @ly2960 2 месяца назад

    Сначала: не давайте больших имён функциям/классам, их сложно читать
    Потом: называем функцию PrintValidTicketsWithMultipliedAmount :D
    А вообще, огромное спасибо, невероятный труд. Даже те кто смог посмотреть от начала до конца заслуживают лайк, что уж тут говорить об авторе

    • @koduryem
      @koduryem  2 месяца назад

      Та знаю. Хотелось именно смысл передать как можно назвать вообще. Если идей короче нет, то ок :)

  • @kirillgerasimov4603
    @kirillgerasimov4603 3 месяца назад

    Лайк не глядя. Буду смотреть дробно и с пометками, спасибо!

  • @Oleg_Zhigulin
    @Oleg_Zhigulin 2 месяца назад +1

    Привет, спасибо за доклад
    буду дополнять по мере просмотра остановился на 1:55:15
    Неточности на мой взгляд:
    0. Про моделировании неплохобы было обозначить что есть акторы, сущности которые взаимодействуют с обьектами и на этапе дизайна их нужно найти например бухгалтер, учитель, ученик.
    1. SRP - это про акторов, как по мартнину его же аббревиату́ра, тоесть лицо или группа лиц которая будет взаимодействовать с обьектами и заинтересованны в их изменении,
    а не про одну ответственность и чистые функции без сайд эффектов.
    2. OCP - ну тут борщ вообще с функциями и фильтрами))), по тому же мартину, написал класс его методы нельзя модифицировать потому что они много где используются в коде и будут проблемы это закрытость, нужно добавлять новые методы что и есть открытость.

    • @koduryem
      @koduryem  2 месяца назад +6

      Привет. Ты тут не прав и упустил весь посыл с первых слайдов, потому что мы не фокусируемся ровно на каких-то определениях Мартина. Это тупиковый путь и black-and-white thinking, fixed mindset. В этом случае, мы не можем нормально накладывать, видоизменять и подстраивать под конкретную ситуацию. Я об этом как раз и говорил в начале и ты бам и попал в эту "ловушку точных определений".
      Ну и чистые функции без side effects не обязательно привязывать именно к SRP. Постарайся быть более гибким и внимательным.
      "Борщ с фильтрами" - та же самая ловушка и мышление в частных случаях и четких определениях. Плюс, некоторая насмешка не к месту. Это почти всегда ведет к проблемам в итоге. Что я свидетель, что множество других людей. Нужно мыслить более универсально, абстрактно, гибко и накладывать паттерны и принципы под конкретную ситуацию. А не пытаться заучить правило и впихивать везде. Это тупик мышления.
      Если хочешь критиковать, постарайся, пожалуйста, учитывать эти факторы, раз мы их обсудили уже в начальных слайдах. Иначе, получается, что мы будем говорить на разных языках и мне придется парировать те когнитивных заблуждения, про которые я предупреждал изначально и которые не имеют смысла. И я вижу, что весь мой изначальный посыл прошел мимо.
      Принципы - это не жесткие определения "делай так" и "Мартин сказал так". К слову, Мартин со мной согласен и много писал об этом. Просто люди идут по легкому пути lazy thinking и пытаются найти жесткие правила и определения, которые "бери и применяй вот так и спина болеть не будет". Сложные и изменяющиеся системы и окружающий мир так не работают.
      Я буду рад, если ты немного переосмыслишь взгляды на более абстрактные и гибкие. Это была одна из целей видео и я немного расстроен, что не удалось ее передать с таким огромным количеством примеров :(

    • @koduryem
      @koduryem  2 месяца назад

      Да, если же ты не согласен полностью енивей, то это тоже окей. У каждого есть право на свое мнение. Это нормально!

    • @Oleg_Zhigulin
      @Oleg_Zhigulin 2 месяца назад

      @@koduryem вот в этом и проблема через чур обильная гибкость и изменчивость и получается что трактовать одно и тоже можно несколькими способами и отсюда понимание совершенно разное
      Для этого же вводили например паттерны чтобы все знали что есть синглтон и это один экземпляр сущности
      Другого описания тут нет и можно всем говорить сделай мне синглтон и он сделает именно его, а не два вложенных списка из алфавита
      Возьмем другой пример с собеседованием на котором тебе задают вопрос что такое молоток?
      - Ну это инструмент которым я буду писать код
      - Вообщето это инструмент которым можно забивать гвозди
      - Ну это у меня широкий майндсет, я не мыслю рамками
      Я думаю что в глазах собеседующего это будет не совсем адекватно, правда? Не брать такого человека на работу
      Другой пример на заправке можно сказать
      заправьте мне топливо
      А какое: бензин 92, 95, 100, этиловый спирт, дизель и тут гибкость вообще не к месту
      Четкое определение это всегда ответственность, а размытое определение это перекладывание понимания на слушателя
      Ты определенно на другом уровне и возможно я пойму твою мысль через время
      P.S.
      О терминах не спорят, о терминах договариваются

    • @koduryem
      @koduryem  2 месяца назад +1

      @@Oleg_Zhigulin ты как-будто на правильном пути; оно гибко да, но его можно представить в виде generic format, который легко свести к частным случаям в любой конкретной проблеме. Что я и сделал - показал generic мышление и потом много разных примеров и для функций, и для классов и для более high level арх-ры. Я делал акцент на этом на протяжении всего видео.
      Не нужно запоминать наизусть определения и частные случаи. Это не работает.

    • @koduryem
      @koduryem  2 месяца назад

      @@Oleg_Zhigulin Можно менять не только задачи, но уровень абстракции и принципы still валидны там и можно применить, с небольшой вариацией и подстройкой (что неизбежно и бороться с этим бесполезно и применять одно частное правило на все случаи без модификаций, что делать пытаются большинство)

  • @horusgrande
    @horusgrande 2 месяца назад

    Смотрел примерно 2 недели по чуть чуть. Досмотрел, приисполнился

  • @ОлександрАбашкін
    @ОлександрАбашкін 2 месяца назад +11

    Взял отпуск чтобы посмотреть до конца 😂

    • @ОлександрАбашкін
      @ОлександрАбашкін 2 месяца назад +1

      Я досмотрел 🎉
      Спасибо за труд! Но я заметил что много тем имеют разные название, но суть очень похожа.
      Наверное это можно тоже как то оптимизировать и декомпозировать.

  • @asadbekegambergenov6881
    @asadbekegambergenov6881 2 месяца назад +2

    Where can i read it from? Could i get a link or something please.

  • @MentorOfMentors
    @MentorOfMentors 3 месяца назад +2

    Дошёл до буквы О, буду держать в курсе

  • @esorramoxin2468
    @esorramoxin2468 2 месяца назад +1

    Начинаю смотреть!

  • @kixt_043
    @kixt_043 3 месяца назад +7

    Ждем тайм-коды ко всему видео 😁

    • @koduryem
      @koduryem  3 месяца назад +10

      Сделал)

    • @kixt_043
      @kixt_043 3 месяца назад +1

      ​@@koduryemБольшое спасибо за старания♥️

  • @Aldovan
    @Aldovan Месяц назад +1

    Лучше 1000 книг!

  • @andry_freeman
    @andry_freeman 3 месяца назад

    Начал смотреть час назад, пока все супер и понятно🙌🏻 надеюсь дальше будет так же)

    • @koduryem
      @koduryem  3 месяца назад +1

      Дальше уже менее психологически и абстрактно и больше примерчиков и картинок, универсальных. Все остальное везде разное может быть гайдлайны и тд, поэтому такое не включал

    • @andry_freeman
      @andry_freeman 2 месяца назад

      @@koduryem спасибо большое за такой труд💪🏻

  • @rightmelancholy1170
    @rightmelancholy1170 2 месяца назад

    лайк за такой крутой бесплатный но на самом деле бесценный образовательный контент

  • @abilvap5611
    @abilvap5611 3 месяца назад +11

    Начал смотреть - 25.09.2024

  • @_curtman
    @_curtman 3 месяца назад +2

    Такой контент и бесплатно, ещё бы ссылку на эту презентацию и вообще идеал.

  • @netneutrality2024
    @netneutrality2024 2 месяца назад +3

    Было бы круто иметь доступ к рисункам Excalidraw.

  • @andrey95875
    @andrey95875 3 месяца назад

    Классный материал конечно, спасибо!!!

  • @АлександрБугримов-о1е
    @АлександрБугримов-о1е 3 месяца назад

    Очень круто, респект! Завтра начну смотреть

  • @vatdaziz
    @vatdaziz 3 месяца назад

    Очень классное видео. Спасибо!

  • @alexei3366
    @alexei3366 3 месяца назад

    11 часов? Сильно. Лайк только за это 🙂

  • @minds_clear_02.23_
    @minds_clear_02.23_ Месяц назад

    Пожалуй начну смотреть и планирую досмотреть за N подходов

  • @dfadfsdfsdsa4283
    @dfadfsdfsdsa4283 3 месяца назад +1

    Воин, кто ты ? :) Спасибо, брат

  • @timofeus91
    @timofeus91 2 месяца назад

    Пока только полтора часа просмотрел . Полет пока отличный

  • @smileroad9111
    @smileroad9111 3 месяца назад +1

    Лайк за старание , 11 часов это жестко. 😂😂😂

  • @shafeemahmoud5769
    @shafeemahmoud5769 3 месяца назад +4

    Привет. А как можно получить эти слайды?

  • @mihahahahahahahah
    @mihahahahahahahah 2 месяца назад

    сильно мужик, спасибо большое!

  • @glavnyi1
    @glavnyi1 Месяц назад

    А можно сказать что open-closed еще и про то, что мы не должны менять базовый класс, а вместо этого должны сделать чайлда и ему добавить методы.
    Например, как на 2:04:22 - базовый person с методом eat, его наследует warrior, который сохраняет eat, но также добавляет figth - это является примером open-closed?

    • @koduryem
      @koduryem  Месяц назад

      Но, ведь ты буквально имеешь доступ к базовому классу, полям, методам в производном и связываешься с ними. Сильная связность

  • @АлексейГлазков-р7б
    @АлексейГлазков-р7б Месяц назад

    невероятно полезны материал! Cпасибо автору
    А где можно взять идеи для пет проекта, чтобы поприменять все техники и паттерны?

  • @ayaulymybraeva767
    @ayaulymybraeva767 3 месяца назад

    я рада, что нашла твой канал! лайк

    • @koduryem
      @koduryem  3 месяца назад

      Заходите, будьте как дома 🏘️ :)

  • @Дмитрийсекрет-н7о
    @Дмитрийсекрет-н7о 3 месяца назад +1

    что бы посмотреть сразу такой курс нужно совершить 12й подвиг Геракла ))

    • @koduryem
      @koduryem  3 месяца назад +7

      Представь, сколько сил ушло, чтобы его сделать :)

    • @Дмитрийсекрет-н7о
      @Дмитрийсекрет-н7о 3 месяца назад

      @@koduryem Это вообще ужас )) много сил и энергии ушло ))

  • @imaynedlog9628
    @imaynedlog9628 2 дня назад

    А есть ли вот этот документик, который уважаемый автор показывает?

  • @lobiritus1512
    @lobiritus1512 2 месяца назад

    Это видео выглядит, как вызов "попробуй досмотри меня".
    Ну что вызов принят, штурмую.

  • @vmike72
    @vmike72 2 месяца назад

    Опечатка в схеме на 43:45 - "We we to.." вместо "We have to" или "We need to"

  • @misterex99
    @misterex99 3 месяца назад

    Сразу подписался, спасибо огромное 👍долгих лет вам жизни коллега 👍

  • @Александр-н3д8ж
    @Александр-н3д8ж 3 месяца назад +1

    Спасибо за труд, мегаполезно

  • @Борьбазадепозит
    @Борьбазадепозит Месяц назад +1

    Спасибо автор! Интересно а сколько времени ушло на создание тайм кодов? Нужно ли было пересматривать свое видео в 11 часов, или все было продумано на стадии планирования?

    • @koduryem
      @koduryem  Месяц назад

      Не очень много, но пришлось машинально проставить. Я примерное помнил, где что, плюс есть план

  • @NOBODY-lk7yo
    @NOBODY-lk7yo 3 месяца назад +1

    Я начал смотреть

  • @sergey37152
    @sergey37152 2 месяца назад

    Огромное спасибо! Можно, пожалуйста, ссылку на текстовую версию?

  • @yehoraltshuler5998
    @yehoraltshuler5998 3 месяца назад +8

    Спасибо за это видео. Попробуй низкие частоты срезать эквалайзером и использовать какие-то плагины по типу izotope rx de click или wawes x click, потому что когда ты тянешь "ааааааааа", у в записи явно выраженный треск твоего горла, не знаю как лучше это объяснить

    • @link_onion
      @link_onion 2 месяца назад

      хапахп треск горла ска

  • @psycho_diss
    @psycho_diss 3 месяца назад +3

    Вау!
    Что называется "психанул", 12 часов базы.

  • @v.demchenko
    @v.demchenko 3 месяца назад

    Спасибо за видео, уже в который раз убедился, что лучшая система это та где есть слой который абстрагирует доступ к какому то модулю. Абстракция занимация вызовом методов.
    Типа забор.

  • @Alex-hz4dk
    @Alex-hz4dk 3 месяца назад +1

    ооо, архитектуровое
    спасибо за вкуснятину

  • @link_onion
    @link_onion 3 месяца назад

    хммм посмотрел вступление, звучит всё это заманчиво

  • @mikhail_dudek
    @mikhail_dudek 2 месяца назад

    Соглашусь с подходом One line one statement. Проблемы в приведенном примере на 3:53:30 принципиально не отличаются от цепочки вызовов через Pipeline. Получается цепочки вызовов тоже лучше не использовать? Типа такого: $this->doSomething()->doAnotherThing()->doYetAnotherThing();

    • @koduryem
      @koduryem  2 месяца назад

      Можно по ситуации. Это же не жёсткие правила. Просто так удобнее отлаживать и поддерживать и в кратковременной памяти держать. Я против жёстких правил. За гибкость.

  • @nurlant4547
    @nurlant4547 8 дней назад +2

    смотрел на скорости 2 и ништяк

  • @yura131314
    @yura131314 2 месяца назад

    Автор молодец, большой был труд проделан по рассказу по чистой архитектуре. Только к видео применил антипаттерн "монолит", сделав одно видео на 12 часов. А как же выделение модулей, плейлиста и прочих принципов про которые ты говорил?

    • @koduryem
      @koduryem  2 месяца назад

      Таймкоды

  • @georgiydemerchyan2913
    @georgiydemerchyan2913 2 месяца назад

    Нереально круто

  • @excavator3571
    @excavator3571 3 месяца назад

    титанический труд, смотрю потихоньку, повторенье мать ученья
    мужик в верхнем левом углу рот открывает не синхронно только :)

    • @koduryem
      @koduryem  3 месяца назад

      Только в начале. Потом норм. Я два раза его снимал и у меня уже сил не было этот кусок переснимать. :)

    • @koduryem
      @koduryem  3 месяца назад

      Сорян за это. Но, я понадеялся, что все ребята норм и будут больше на контент смотреть, на пользу. И вроде так и есть, что радует 😁

  • @alexandr1408
    @alexandr1408 2 месяца назад +1

    Грандиозная работа. По сути изложение идей из книг Фаулера, Мартина, а также хорошие практики из опыта, но в формате видеолекции. Не знаю, правда, насколько это будет доступно к пониманию новичкам, скорее, для более менее опытных разработчиков, т.к. все излагается на уровне абстракций (что хорошо).
    Недавно тут была статья на хабре (ссылки нету, можно поискать), где описывалось, как один парень зарубился с Мартином, мол, чистый код - такое себе. Оригинал не читал, объектьивно оценить доводы тяжело, но из самой статьи сложилось мнение , что тот парень или из "черно-белой секты", или просто решил хайпануть, но приведенные доводы вообще были ни о чем (на мой взгляд). К чему это я? К тому, что изложенные в видео мысли на практике действительно очень полезны на больших энтерпрайз-проектах, и не как свод правил, а именно концептуально.
    P.S. "Перевод каретки" ... аж нафталином запахло ))
    P.P.S. Ага, в телеге предпоследнее сообщение, похоже, именно про "того парня".

    • @koduryem
      @koduryem  2 месяца назад

      Спасибо)

    • @koduryem
      @koduryem  2 месяца назад

      Да, там наглядный пример)

  • @LaraNewYork
    @LaraNewYork 3 месяца назад

    Привет вот тебя интересно слушать! Работаю и слушаю параллельно. Что то залетает в голову что то нет

  • @evgeniy4831
    @evgeniy4831 2 месяца назад

    в 1080p есть возможность загрузить, чтобы совсем красиво было?

    • @koduryem
      @koduryem  2 месяца назад

      к сожалению нет(

  • @xyzwio
    @xyzwio 2 месяца назад +1

    Каждый раз убеждаюсь что SOLID это про то сделать код в 10 раз более сложным и в 100 раз более медленным. Вы объясняете как сделать тривиальные вещи невероятно сложным способом, похоже на Rube Goldberg machine.

    • @koduryem
      @koduryem  2 месяца назад

      В точности наоборот объясняю. И не говорю, как "правильно делать и только так", а когда где и почему и в какой ситуации. И почему именно там именно оно надо и другое хуже будет. Будь внимательней, а то как-будто не смотрел, а мнение составил :)

    • @koduryem
      @koduryem  2 месяца назад

      Если хочешь, можешь более детально привести пример, расписать, как бы ты сделал с учетом твоего контекста. Чтобы не было абстрактно "все херня"

    • @shafeemahmoud5769
      @shafeemahmoud5769 2 месяца назад

      @@koduryem вы объясняете очень хорошо, просто xyzwio не имеет достаточного опыта и предварительных базовых знаний для того, чтобы вникать в эту тему.
      С моим опытом (а это посмотрел и переписал пару приложений на чистой архитектуре, еще нет опыта работы), всё хорошо заходит и структурируется в голове.
      Кстати, Вы не ответили на мой вопрос, к сожалению, про то, как можно получить слайды из видео. Спасибо.

    • @xyzwio
      @xyzwio 2 месяца назад +1

      @@koduryem Спасибо что ответили! Мой комментарий был через чур эмоциональный. Не думаю что формат YT комментариев подойдет для таких дискуссий. Позиция которая мне ближе всего в этой теме хорошо изложена в видео "Clean Code Horrible Performance".

    • @koduryem
      @koduryem  2 месяца назад +1

      Видео довольно манипулятивное и рассматривает искусственный пример, оторванный от реальности.
      1) "they tell you never ever do that" - кто "they"? Анкл боб сам же пишет - используй свитч, если удобно и размер проекта позволяет. Об этом и я говорил тоже. Почему "они" так говорят - первые темы, про которые мы говорили об ограниченности мышления и желания взять 1 инструмент и везде его использовать. Мы не рассматриваем серьезно такие вещи. "они говорят" - не конструктивно и biased, направлено на создание того восприятия, которое он хочет
      2) Что такое "clean code" - он дал свое манипулятивное определение без каких-либо оснований и аргументов ("вот так полиморфизм заюзаешь вместо свитча - это и есть clean code"). Это уже нивелирует все, что он говорит. Я дополнительно делал акцент на том, что clean code - не инструмент "делай вот так", а принципы, применяемые в нужном месте и время, по ситуации, при эволюции кода. Этот же его код в маленьком проекте будет "clean", а на сотни тысяч строк оно становится big ball of mud, который можно просто выкинуть. Но, кто бы знал что за деревьями есть лес.
      3.1) Он на серьезных щах сравнивает разницу между 35 vs 25 cpu cycles. Буквально, 1 cpu cycle on 4Ghz processor == 0.25ns => 35 * 0.25 vs 25 * 0.25 => 8.75ns vs 6.25ns. Это уже просто смешно. В добавок, это сравнение идет при прогоне бесполезной программы 1000 раз карл! Если мы, например пишем любой бекенд, шанс, что твой workflow прогонит разного рода объекты 1000 раз очень мал. И даже если вдруг, то.... 9 НАНОСЕКУНД . Такое можно еще считать , если мы ракетостроением занимаемся или жесткими embedded (и то современные ембеддед типа телефонов и планшетов даже не заметят этого). Значит, прогнать подобное 1 000 000 раз будет 90 нс, 1 000 000 000 раз - 1мс. Часто, если у нас бд, к примеру, наш запрос может отработать и за 100-300мс, что вообще 10^8 больше, чем он прогоняет 1000 раз свои объекты для вызова 1 метода => это просто капля в море. Могу миллиарды раз так гонять, и пользователь не заметит даже.
      3.2) Код стал хуже читаться, поддерживаться, на мастшабах это может убить проект (десятки тысяч строк мб еще ничего или если это инкапуслировано в одном модуле). Теперь каждое место по всей программе должно знать ВСЕ типы объектов, чтобы написать логику. И все поля структуры, чтобы писать логику. Мы не можем просто принять интерфейс и вызвать метод. Нет. Теперь пиши функции и там перебирай все типы объектов. А если что поменяется - меняй их ПО ВСЕЙ программе (представьте в сотне тысяч строк поменять). В своем и даже абсолютно чужом коде, где ты без понятия, что люди делают и как и что изменить надо правильно. Nice.
      4) Подумайте, почему комменты закрыты полностью? Хоть бы позитивные оставил, мы бы advantages от туда взяли.
      5) Оптимизации со switch -> hash table не всегда возможны и нужны. Только в узких моментах. Эта оптимизация абсолютно бесполезная, если у нас бизнес логика, а не программирование микроконтроллеров. Хотя, я так иногда тоже делаю, где возможно. Но не для мега оптимизаций, а читаемости кода или удобства.
      6) Подобный подход "в лоб" можно использовать, при разработки в agile style (и мы так делали в видосах). Без лишних абстракций и тд. Когда маленький проект и оч мало людей на нем (1-2-3). Все работает, быстро. ок. Скрыто в небольшом модуле. Ок. Легко понять, читать много не нужно. НО! Даже там мы не будем оптимизировать до талого код, который мы 100% удалим и поменяем на другой, когда проект начнет становиться больше. Или когда эти оптимизации не рациональны в нашей задаче (90% случаев). Значит, мы потратим очень много ресурсов на оптимизации, которые не нужны ни в проекте, ни бизнесу (пара наносек - это не о чем). Такими вещами типа байтодрочева занимаются в чрезвычайно узких местах.
      Человек не понимает, что код пишется не просто так и что его надо поддерживать множеству людей и команд. Что requirements у бизнеса в большинстве случаев не оптимизация до наносек. Не "скорость" ради скорости. А имплементация бизнес логики и решения задач ОПТИМАЛЬНО. Чтобы в этот код можно было легко вносить новые изменения и фичи, оптимальная скорость, минимум кода и cognitive complexity, чтобы команды не конфликтовали при разработке и тд.
      Если я на интервью скажу "я оптимизирую код по максимуму и если потом кто-то захочет что-то в нем изменить, ему надо будет перелопатить сотни тыщ строк и везде принять решение, что и как изменить, чтобы ничего не поломать; clean code говно; зато очень быстро будет!", скорее всего даже у hr'а, кто не в теме, случится когнитивный диссонанс.
      Если бы он просто сказал "ребят, вот такое мнение вот для такой конкретно задачи" - то ок. Ну, я тоже бывает ляпну что-то и как-бы не парюсь, не хочешь не делай. Когнитивное же искажение в виде генерализации с примесью манипуляций "вы видите, я взял пример на 200 строк и разбил эти ваши мифы про клин коды" - ну как-бы такое :)

  • @Mikola1982Lt
    @Mikola1982Lt 2 месяца назад +1

    Очень рекомендую поработать над речью и избавиться от слов паразитов: "Ну типааа", "Типа даааа" и вот это вот всё.
    контент очень годный

    • @koduryem
      @koduryem  2 месяца назад +1

      Прости что заставил тебя страдать :)

    • @Mikola1982Lt
      @Mikola1982Lt 2 месяца назад

      ​@@koduryem ну типа ок

  • @AleksandrIlyin
    @AleksandrIlyin 3 месяца назад

    Спасибо за видео!) Дай совет или сними ролик по изучению английского, свой путь конкретно

  • @landnevermind
    @landnevermind 3 месяца назад

    Спасибо ! К чему это прихлобучить ?

  • @featureless6022
    @featureless6022 3 месяца назад +24

    ты чево какие 12 часов

    • @monsvta
      @monsvta 3 месяца назад

      ахуенные

  • @Дмитрий-ю9к3г
    @Дмитрий-ю9к3г 3 месяца назад +2

    Опаааа! Потираю руки.
    Читаю "Совершенный код" сейчас я думаю, почему в видосах никто это не освещает? И тут на тебе

    • @kirillsabko1405
      @kirillsabko1405 3 месяца назад

      RUclips давно читает твои мысли😀

  • @fravisxgod7600
    @fravisxgod7600 3 месяца назад

    Приветствую! Выражаю огромную благодарность за проделанную работу.
    Хочу задать вопрос по теме Loops: вы предлагаете вместо одного for сделать несколько. Для меня это непонятно, это же влияет на производительность, можете пояснить свой выбор? По вашему мнению можно жертвовать производительностью в счет улучшения читаемости и поддержки этого кода?

    • @koduryem
      @koduryem  3 месяца назад +2

      Одно действие за раз, которое потом протрейсить могут проверить. Все верно.
      Производитель можно и нужно жертвовать. Обычно это нишевые области, где она будет влиять как-то. И даже там это можно легко делать, если это не bottleneck. Смотреть amdahl law. Оверфокус на производительности не продуктивен и часто смысла не имеет. Мне нет дела до твоей супер оптимальной функции, которую я почти не вызываю. А если в ней будет баг, а тебя в компании больше нет, то разбираться и тратить время опять же мне. Чтобы так делать, надо показать необходимость жестких оптимизаций и отдельно их описать рядом, что, почему и как

    • @fravisxgod7600
      @fravisxgod7600 3 месяца назад

      @@koduryem ответ исчерпывающий, спасибо большое!!

    • @koduryem
      @koduryem  3 месяца назад +1

      Оверфокус на производительности часто дает пренебрежимо малые ее прирост, особенно в бекенде, а вот количество говнокода просто огромное. Преждевременные оптимизации - зло. Straustrup врать не будет

    • @koduryem
      @koduryem  3 месяца назад +1

      Люди, потратившие огромное количество времени на изучение низкоуровневых оптимизаций, будут до последней капли крови доказывать, что они везде нужны и надо писать сразу четко, оптимизировано. Только так правильно. В мире и так много плохих программ. И тд. Здесь нужны замеры и бенчмарки. А также трейдоф по времени реализации этих оптимизаций, сколько они дают, сложностью поддержки таких решений и требований бизнеса

    • @fravisxgod7600
      @fravisxgod7600 3 месяца назад

      @@koduryem спасибо большое за ответы и преданность своему делу! Очень полезно

  • @Niki-nx6cd
    @Niki-nx6cd 3 месяца назад +8

    Кажется ютуб нулем ошибся

  • @LaraNewYork
    @LaraNewYork 3 месяца назад

    Интересно было бы вместе какой нибудь подкаст записать

  • @now.7348
    @now.7348 3 месяца назад

    Во. теперь знаю подо что засыпать ближ.дни😊

  • @beavissooqa7585
    @beavissooqa7585 3 месяца назад

    так.. я пока только 18 минут глянул.. там дальше в видео будет сончас?)