Архитектура очень интересна, чем больше видео будет - тем лучше ! Спасибо !
@vitprof5 жыл бұрын
С моей точки зрения важно понимать какому уровню абстракции принадлежат описываемые паттерны. Если паттерны Банды Четырех применяются непосредственно при написании кода (его структурировании), то паттерны GRASP относятся к более высокому уровню абстракции (архитектурные паттерны), так же как и принципы SOLID. Использование паттернов для разработчиков - не плодить сложные абстракции и не изобретать велосипеды. Несмотря на то, что ООП позволяет реализовывать сложные проекты, он довольно сложный и не совсем естественный. Очень часто разработчики переусердствуют в придумывании ненужных абстракций. Всю эту концепцию еще важно дополнить принципом Бритвы Оккама.
@serhiis_5 жыл бұрын
где вы были когда sun писали java 6? throws в каждом методе сдк - хватит это терпеть!
@Pitometsu5 жыл бұрын
Проблема паттернов в ООП. Проблема ООП в том, что это _несколько_ техник воспринимаемых как одна, некоторые из которых, строго говоря, анти-паттерны. Хорошая статья по теме: medium.com/@stephenebly/an-introduction-to-existential-types-25c130ba61a4
@kandreyk91595 жыл бұрын
@@Pitometsu проблема паттернов в том, что помогая в решении одних проблем, они порождают другие проблемы, требующие новых паттернов...
@AndriiKuftachov5 жыл бұрын
ООП - это абстракция, которая не соответствует современным веб-симтемам. По сути, люди просто объединяют какие-то данные с методами в классы, но это совсем не то. Например, Контроллер - это просто набор методов. Дальше, если Модель не анемичная, то ни все равно её не хватит и придется использовать сервисы. Мыслить категориями объекта хорошо тогда, когда реально моделируем поведение объекта, например, UI или в играх.
@aliorunity3 жыл бұрын
Я бы еще добавил YAGNI и KISS
@vzzzk5 жыл бұрын
Вот очень правильно сказал. В сети до фига теории, с пояснениями, простейшими примерами и т.п. Но как только дело доходит до практики, конкретной задачи, то начинаются трудности с применением этих знаний. Зачастую совершенно непонятно, на каком паттерне/принципе/шаблоне построить ту или иную часть системы. Хотелось бы увидеть больше видео с демонстрацией применения теории на конкретных задачах. Не так важно каких именно принципов и на каких языках/технологиях. Важнее понять ход мысли при проектировании.
@zultulce5 жыл бұрын
Согласен, я думал, что голова лопнет от понимания. Со скрипом по книгам проходит, мало демонстрации, а то, что встречается в видео, то это как хауди - за час java, за час php и прочая херня!
@ПавелКуликов-и3м5 жыл бұрын
а не надо строить систему на паттернах, их нужно применять только когда возникает проблема в проектировании (нарушение принципов и тд)
@__alexfox__5 жыл бұрын
Очень интересная тема. Несколько раз переслушивал ролик! Пожалуйста, больше!!!
@NookeSt5 жыл бұрын
Было бы интересно про иерархию шаблонов, принципов проектирования. Как пересекаются, какие взаимосвязи.
@goliafffff5 жыл бұрын
Тема архитектуры приложения очень интересна, с удовольствием посмотрю об этом видео.
@Pitometsu5 жыл бұрын
Спасибо большое. Прекрасно разделение принципов проектирования и паттернов, т.к. первые ложатся не только на ООП, но и на структурное, модульное, и функциональное программирование, помогая проектировать грамотный DSL и повышая переиспользование, и упрошая поддержку. Хотелось бы послушать о распределенных архитектурах, если будет желание о них рассказать, например.
@lavcoder5 жыл бұрын
Сделай видео про CQRS. Кто за, ставь лайк!
@Pitometsu5 жыл бұрын
И про кеширование. И про event sourcing до кучи!
@АндрейРеш-г9в4 жыл бұрын
Да. Просто нужное. Нужно. И Вы очень интересный Чел. Пробую на ходу. Обязательно сообщу - что нужно и как это классно. Сама подборка видео по архитектуре -какая то очень-очень творческая и хорошая.
@Василий-е2ш4щ4 жыл бұрын
Отличная лекция, спать не хочется, очень интересно
@ЮраГайдучик-э4о5 жыл бұрын
Архитектура интересна!) Спасибо за видео. Хочется больше видео по DDD, принципы, слои, примеры реализации.
@drVatman5 жыл бұрын
Было бы интересно увидеть ваш список проектов с открытым исходным кодом, которые вы рекомендуете как примеры хорошей архитектуры. Чем больше и разноплановее тем лучше.
@lavcoder5 жыл бұрын
Сделай видео про микросервисную архитектуру. Кто за, ставь лайк!
@Pitometsu5 жыл бұрын
Особенно о том, как решать проблему переиспользование кода. И как делать CI/CD и версионирование всего этого добра с поддержанием консистентности.
@omgoood5 жыл бұрын
Да забейте, без нормального штата не вытянуть микросервисную архитектуру. А все видео чисто абстрактные
@voothi3 жыл бұрын
Очень интересная тема, спасибо! Стало понятно как связаны подходы
@dmitrypichugin74495 жыл бұрын
Я из GRASP запомнил только 6 из 9 шаблонов. Другие это полный клон SOLID, или очень похожие. Для себя выделил приблизительно такие ключевые определения: 1) Информационный эксперт - владелец знаний, сами их обрабатывает. 2) Креатор - создает объекты тот кто обладает всей необходимой для этого информацией, чаще других их использует и/или агрегирует в себе. (аналог фабричного метода и абстрактрой фабрики) 3) Контроллер - отделяет UI от логики приложения. 4) ЛоуКоплин - классы должны быть как можно меньше связаны между собой, и знать о внутреннем устройстве друг друга. 5) ХайКохесин - класс должен выполнять только ту работу для которой он создан, например класс работающий с сетью должен работать только с сетью и ничего больше. (и это не S из SOLID, там речь про акторов (групп пользователей)) 6) ПьюрФабрикейшн - это когда в программной реализации используются понятия не существующие в предметной области, например - репозитории и БД. Нужно для удовлетворения другим шаблонам. Например, следуя шаблону информационный эксперт, класс сам бы сохранял себя в БД, но это не круто, поэтому и ORM etc. Чем больше шаблонов, тем больше связей между ними.
@TimothyNazar5 жыл бұрын
Среди всех призывов коментировать только это видео смотивировало :) Очень буду ждать видео на тему: "Проектирования приложений - основные подходы" или в формате потенциальных вопросов которые ты бы задал кандидату на позицыю архитекта.
@fpv_am5 жыл бұрын
Как же круто что я понимаю это, и вспоминаю реальные примеры из реальных проектов, хоть и кажется вчера ничего не знал о программировании, так что программирование это действительно просто, по крайней мере бэкэнд архитектура.
@RobinGoodwe8725 жыл бұрын
Наверное, необходим обзор архитектур. Где на практике какие подходы применяются, а затем рассматривать отдельно.
@sovrinfo2 жыл бұрын
Спасибо за видео.Коммент в поддержку!
@МедведьСтранник5 жыл бұрын
Спасибо за ролик. Тема актуальная. Как по мне, будет интересно обозначать проблему, а затем выдвигать архитектурное решение. Тогда, паттерны будут к чему-то привязаны и в голове что-то отложится. Думаю, имеет смысл рассматривать [не все подряд] шаблоны из разных групп: паттерны банды четырёх, паттерны DDD, шаблоны микросервисного взаимодействия
@AntiPolarity4 жыл бұрын
Поддерживаю архитектурные видосы!
@4Funoff2 жыл бұрын
Уже почти три тысячи лайков 😊 ждём продолжения!! Видео классное, благодарю!!
@AAAGaming695 жыл бұрын
Видео супер, как всегда! Очень хотелось бы послушать про этапы проектирования архитектуры
@АленаЕршова-ъ5ю8 ай бұрын
супер, очень интересное и понятное объяснение!
@savalex19905 жыл бұрын
Давайте больше архитектуры. Это очень востребовано.
@egordoynikov85975 жыл бұрын
спасибо! могли бы вы поделиться опытом ,как и какие проблемы вы решали на практике с помощью паттернов проектирования и что из этого вышло в плане прозрачности кода и производительности системы. Стоит ли строго ограничивать проект каким-то набором паттернов? Были ли случаи на практике, когда паттерны излишне усложняли код проекта или паттерны это всегда догма и городить лес из абстракций просто необходимо , чтобы код оставался единообразным?
@Freddis3 жыл бұрын
Такого вопроса в принципе быть не должно. Паттерны проектирования (GOF) надо использовать тогда когда знаешь, что они нужны и помогут. А GRASP паттерны можно использовать всегда, они почти не оказывают влияния на абстракции и тем более код. По сути это не техники какие-то, а то, как ты должен в голове распределять обязанности между классами. Фактически только ты один будешь знать, что они использованы. Найти их в коде будет невозможно - просто код будет причесанным и не будет вызывать проблем.
@terminakter5 жыл бұрын
Было бы интересно посмотреть про архитектуру баз данных, как лучше всего хранить/считывать/заполнять через встроенные функции СУБД данные, чтобы не было проблем в будущем. Например в тематике бронирование времени
@timofey90524 жыл бұрын
4:32, низкое зацепление и высокая связность, наоборот должно быть. А, у вас зацепление и связность перепутаны
@arsenykonohov7 ай бұрын
low coupling high cohesion - низкая связь высокая связность (google translate). Возможно лучший перевод мог бы быть "Низкая связанность (с внешним) высокая концентрация (на задаче)" чисто по контексту задачи этого патерна.
@LeonwPRO5 жыл бұрын
Хочу узнать всё что только можно об архитектуре. Прям сложно определиться что выбрать. Отличная тема! Спасибо
@pavelnemoi5 жыл бұрын
Спасибо вам за контент! Архитектура скорей всего интересна почти всем, думаю видео в этом направлении будут пользоваться спросом большой аудитории. Хотелось бы послушать ваше мнение о практической реализации конкретной архитектуры приложения в проекте, к примеру, Onion или Hexagonal, CQRS architecture. Важности знакомства с ней разработчиков и объяснения основных принципов.
@NadChel1 Жыл бұрын
Отличное видео, спасибо!
@cffee_5 жыл бұрын
Интересует MVVM vs MVC
@Mike-hp3fh5 жыл бұрын
Мне интересна какая-то систематизация архитектурных решений и базовый фундамент. Пока для меня многие шаблоны проектирования как склад инструментов которые непонятно как и где использоватиь и с чего вообще начинать разработку приложения. Для себя я выделил следующие фундаментальные принципы: * Модульность. * Один модуль - одна ответственность. * Продуманные интерфейсы модулей. Они должны быть как можно меньше и как можно более функциональны. При этом не так важно как реализованы сами модули, их потом можно переписать или связать с этим интерфейсом другие модули * Предпочитать стандартные интерфейсы, т.к. они проверены на практике и дают возможность легко подключать свои модули к другим, которые тоже придерживаются стандартов. * Минимальная зависимость модулей друг от друга. Лучше перенести в модуль какой-то небольшой код из другого модуля, чем зависеть от него целиком. * Универсальность модулей. Модуль должен как можно полнее охватывать спектр задач из области своей ответственности. * Простота модуля. Чем меньше кода - тем лучше. Модулями могут быть классы, функции, наборы связанных классов, компоненты, и пр. Самый главный принцип - это продуманые интерфейсы, которые разработать довольно сложно.
@ИванНикитин-ч7б5 жыл бұрын
Интересует слоистая архитектура мелких переходящих в средние программ. То есть, подробный пристальный архитектурный разбор, в какой последовательности происходит проектирование разных слоёв программы. Как грамотно и полно спроектировать архитектуру и внутренний дизайн мелкой/средней программы до этапа написания кода.
@ziyadseykhanov3967 Жыл бұрын
02:08 Уже больше 3000 лайков. ))
@TimurSevimli Жыл бұрын
:)
@popuzin2 жыл бұрын
Архитектура интересна. Продолжайте пожалуйста :)
@PoletaevRoman5 жыл бұрын
Про архитектуру очень интересно
@mamkinproger5 жыл бұрын
увидел видео. думаю, о сейчас посмотрю кое-что для себя полезное(я начинающий). в ходе просмотра понял, что пока ничего не понял - отложил на время до лучших времен. А так, спасибо за полезный контент!
@MrBivanovs Жыл бұрын
лучшее объяснение без воды
@user-friendhors Жыл бұрын
какой умный человек!! спасибо за ценную информацию!!!
@tinkerbel19555 жыл бұрын
Как уже отметили в комментах, о том что хотелось бы увидеть сам ход мыслей при выборе паттерна.. что-то вроде: "я собираюсь подобрать паттерн для X проекта, и найболее подходящие кандидаты на роль паттерна конкретно этому проекту: паттерны 1 два и три (а причины почему именно они это ... и т.к. 1 и 2ой паттерн довольно так похожие в.. но..)... НО я остановлю свой выбор на втором паттерне, по целому ряду причин.. А так же взглянув на опыт проектировщиков, таких сервисов как * * *, можно понять что мой выбор не является ошибочным."
@танунахепта5 жыл бұрын
Пока что я понимаю так, качественные источники можно связать головой. Это про то что в конце видео.
@slavanslavan93302 жыл бұрын
Низкая связанность (Low Coupling) и Высокое зацепление (High Cohesion), а не наоборот же
@MelineWald3 жыл бұрын
Спасибо за такое хорошее обьяснение
@0imax3 жыл бұрын
Интересный взгляд. Но мне больше нравится объяснение от Немчинского.
@only_noma3 жыл бұрын
Да, видео по архитектуре нужны, так как у меня, лично, с этим есть пробелы. Будет здорово получить еще какое-то поле для размышлений.
@ЕвгенийБабурин-х5х Жыл бұрын
приятный паарень, голос тоже. Я открыл видео поскольку искал конкретный пример на GRASP контроллер и этого мне и не хватило :(
@Lisa___9c5 ай бұрын
Several stories of empty rooms rewarded their search, but nothing more; so after a time they came back to the platform again.
@chu_ri54704 жыл бұрын
Да да да, архитектура. Хочу хочу хочу. Да видео вышло год назад, но архитектура.... Я её чувствую. Она нужна мне.
@batyr715 жыл бұрын
Пожалуйста, по архитектуре побольше. 👍👏
@mikhaildiesperov23452 жыл бұрын
Ну конечно нужны такие видео. Нужны такие выжимки.
@Richard___525 ай бұрын
I hope you're grinning all the way.
@EugenBatmanoff3 жыл бұрын
Отличное видео, очень своевременно, т.к. злобные собеседователи уже лупят сложные вопросы по паттернам уже для ранних мидлов ( говорю про свой опыт Java дева). А в этих паттернах всё весьма запутано и абстрактно.
@ЕгорТвердохлеб-й2р3 жыл бұрын
круто изложили инфу! приспект!
@Cleannetcode5 жыл бұрын
Очень интересует данное направление. Хотелось бы послушать ваше мнение: - чем отличается архитектор от проектировщика? - может ли заказчик влиять напрямую на проектно/архитектурное решение или все такие за это должен полностью отвечать разработчик? - на каких этапах роста проекта стоит делать ревью проекта?
@petrplotnikov43073 жыл бұрын
не совсем понятно как определить что должно быть в моделе, как определить что относится к бизнес логике?
@InkeriLantieri5 ай бұрын
An insider's perspective: exclusive interview with Binance's CEO on future developments
@mutniytip20003 жыл бұрын
Мне в принципе очень интересна тема архитектуры, не имею большого опыта в программировании, и хочу знать все и обо всем)
@madmad72015 жыл бұрын
Здравствуйте:) О GRASP толком ничего не слышал, но очень интересно
@vasilys97765 жыл бұрын
Годно, пили ещё в том же ключе
@himyl135 жыл бұрын
Привет! Меня вот мучает такая проблема в архитектуре, что не всегда понятно, стоит независимую логическую задачу выносить в модули или контроллеры. Я стараюсь сделать так, чтобы ни один модуль не зависел от другого и с ними работали только контроллеры, но встаёт ситуация, что типичная операция должна включать в себя несколько процессов и.. тут дилемма в каком виде лучше организовать не создавая зависимости.
@Mark___551x5 ай бұрын
Taking it one step at a time-refund details and expected actions
@VYACHESLAVx4 жыл бұрын
Спасибо)
@mihaelvetkin32574 жыл бұрын
После окончания универа испытываю нехватку знаний по архитектуре. Приходится всё собирать по крупицам
@dmitriy11295 жыл бұрын
Для начала, С ДНЁМ ПРОГРАММИСТА!А по делу: GRASP, SOLID и т.д. по факту не имеют принципиальной разницы
@nikshadow925 жыл бұрын
Будет бомба если этот мужик разжует Liskov principe, мда, SOLID много где спрашивают)
@НикитаГлухов-п5ю4 жыл бұрын
А че его разжевывать, он простой как пробка на практике, так как там есть конкретные определения, тот принцип "единственной ответственности" гораздо более абстрактный и понимаемый скорее интуитивно. Принцип подстановки Лисков - подкласс должен дополнять контракт родителя, а не замещать его (т.е. предусловия нельзя усилять, постусловия - ослаблять, инварианты класса нужно сохранять). Вот и всё.
@nikshadow924 жыл бұрын
@@НикитаГлухов-п5ю я именно так и понимал его всегда (никаких оверрайдов). На практике как раз таки доовольно тяжело создать иерархию в которой не будет таких нарушений. Но понимать этот принцип и почему переопределения - плохо, важно, да
@tanyagibadulina8809 Жыл бұрын
Хорошо рассказано
@andreykhalepov82605 жыл бұрын
По построению архитектуры очень мало информации в интернете. Было бы здорово
@user-QesOrwuMqN5 жыл бұрын
Расскажи что знаешь по DDD
@atlasua20214 жыл бұрын
DDO?
@user-QesOrwuMqN4 жыл бұрын
@@atlasua2021 domain driven design (DDD)
@itcloudguy5 жыл бұрын
Я работаю на паттерне MVVM. Пишу корпоративное десктопное приложение на C#. Хотелось бы узнать, в какой момент можно понять, что ты нарушаешь этот паттерн. Но возможно это вопрос немного специфичный.
@caffeinejavacode14752 жыл бұрын
как рекомендуете попрактиковать чтоб их лучше понять?
@xabikiqwe5 жыл бұрын
Всегда было интересно насколько избыточны все эти программные конструкции. Да, конечно нужно учитывать последующую поддержку кода и величину системы, но всё равно вопрос актуален. Насколько выгоднее было бы писать не структурированный по паттернам код?
@spathochu5 жыл бұрын
спасибо!
@freestailist5 жыл бұрын
Сними пожалуйста про работу с данными в ангуляре, используешь сторы (если есть опыт использования сторов на реальных проектах, то плюсы и минусы их), сервисы или все в компонентах хранится, плюсы и минусы данных подходов
@RezetRoy4 жыл бұрын
сторы от лукавого (мода)
@ajajapenoflex5 жыл бұрын
Устойчивость к изменениям разве не относится к принципу открытости\закрытости?
@S0ERDEVS5 жыл бұрын
Это один из вариантов реализации.
@ILMIRazmach5 жыл бұрын
Спасибо за контент. Да, видео про архитектуру очень было бы полезно послушать, этого не хватает на русском языке. Очень часто возникает сложность продумать архитектуру проекта. Я конечно понимаю что архитектура создается под проекты. Было бы интересно послушать на примерах каких то проектов, например построение архитектуры для какого то проекта, и почему архитектура построена так, а не иначе, и какие она проблемы решает.
@ifastenko5 жыл бұрын
Высокая связность и слабое зацепление напрямую связаны с устойчивостью к изменениям, т.е. с выделением интерфейсов. Яву , такие как java, подталкивают разработчиков связывать классы разрабатываемой фичи в один пакет. Там даже специальный модификатор доступа есть. Внутри пакета может быть много связей между классами, это и есть высокая связность. Но вот взаимодействие между пакетами происходит через интерфейсы, желательно с низким колвом методов. Гдето даже слышал, что желательно не более 5 на интерфейс, и не более двух-трех интерфейсов на пакет. Это и есть слабое зацепление.
@AndriiKuftachov5 жыл бұрын
Это ты ещё про Go не знаешь 😉
@ДжонСноу-я8э5 жыл бұрын
грамотный мужик, лайк
@maksimsergeevich59392 жыл бұрын
Посоветуйте пожалуйста лекции или выступления где также хорошо рассказывают про построение просто больших программ: 1000,10000,100000 строчек кода. Потому что, пока, я это воспринимаю как искусство: не утонуть в объеме кода который ты сам написал. Ведь с увеличением программы неизбежно увеличивается связанность кода даже если ты стараешься ее избежать. Как писать большую программу так чтобы она не превращалась в лапшу из гoвнокода с увеличением объема?
@АркадийПотапов-з9т5 жыл бұрын
Ничего не понял, но очень интересно!
@Termonna5 жыл бұрын
Архитектура очень нужна. Я запутался, как в коде реализовать ассоциации и чем на коде она отличается от агрегации :с В разных источниках пишут разные примеры и не понятно, а какой из них правильный. Пока что свожусь к мысли, что ассоциации и агрегация реализуются одинаково, просто в агрегации агрегируемые экземпляры могут принадлежать только к одному экземпляру класса-агрегатора. В общем, очень не хватает понимания, как теорию реализовать на практике
@vll19765 жыл бұрын
"В MVC framewёrках" - оговорка по Фрейду, что называется...
@МедведьСтранник5 жыл бұрын
Что ты хочешь этим сказать - типа, фрэймворк не может базироваться на паттерне MVC?
@NecroRomnt5 жыл бұрын
Нахожусь на позиции middle fullstack developer. Постоянно ощущаю нехватку знаний об архитектурных подходов, но наибольшие сложности появляются когда пытаюсь применить неосвоенный подход. Часто получается нелепо и требуется время на причёсывание кода, а времени, естественно, нет.
@qdexy5 жыл бұрын
Архитектура это самое сложное для меня
@eleimt4 жыл бұрын
Видео том, как SaaS поддерживать для пользователей. Как вносить изменение для каких-то клиентов, и как это поддерживать.
@alexeyveseliev1065 жыл бұрын
Лайкаем, лайкаем!!!
@cultofsogga58635 жыл бұрын
Кому помогло в жизни употребление и курение грибов???
@maratimus5 жыл бұрын
Я хочу начать микродозить через день псило - сила, в долине многие коддеры юзают
@karim40465 жыл бұрын
Что оно даст на практике?
@Skellag5 жыл бұрын
@@karim4046 +1-го торчка через лет 5
@ДанилПархоменко-й5я5 жыл бұрын
где купить такие очки ?
@didexdida16975 жыл бұрын
Как визуализировать архитектуру проекта?
@valentinkhomutenko63085 жыл бұрын
UML диаграммы
@Ren-z5m3t11 ай бұрын
Лучше слова подкреплять текстом, а не мимикой. Но зашло. Спасибо
@ЕрболУтегенов-й5ю5 жыл бұрын
Soer ты самый зрелый и адекватный из всех IT-ютуберов; хотя было время я смотрел инфоцыган типа winderton, каюсь
@monoteiz5 жыл бұрын
Расскажи про ИИ
@ЖораКруг-б5в Жыл бұрын
Принцип единственной ответственности не про единственную ответственность, а про зависимость от одного актора и не совпадает с high cohesion. А в целом норм😅
@sergeyintegral4515 жыл бұрын
Было бы интересно послушать про саги.
@ringnull Жыл бұрын
Я испытываю нехватку знаний по архитектуре.
@dmitryb5304 жыл бұрын
И где супер ПО написанное по всем этим правилам??
@nikshadow925 жыл бұрын
Помнишь все GoF? Не забывай про KISS )
@davidapk3233 жыл бұрын
спасибо
@ivan101ist5 жыл бұрын
Тот случай, когда утрамбовал свои идеи в чей-то неуклюжий кубик(GRASP).