Тёмный

Декоратор (Decorator) ► Шаблон проектирования Урок №20 

Dmitry Afanasyev
Подписаться 26 тыс.
Просмотров 9 тыс.
50% 1

Декоратор (Decorator) - достаточно простой шаблон проектирования, но с нюансами использования.
Изучим определения паттерна из различных источников, рассмотрим примеры из википедии и создадим два своих примера использования. Так же рассмотрим ошибки применения шаблона.
Декоратор (англ. Decorator) - структурный шаблон проектирования, предназначенный для динамического подключения дополнительного поведения к объекту. Шаблон Декоратор предоставляет гибкую альтернативу практике создания подклассов с целью расширения функциональности.
Задача - Объект, который предполагается использовать, выполняет основные функции. Однако может потребоваться добавить к нему некоторую дополнительную функциональность, которая будет выполняться до, после или даже вместо основной функциональности объекта.
#шаблоны_проектирования #Декоратор #laracast
00:00 Начало
00:53 Определения паттерна Decorator
05:11 Разбор примеров шаблона из википедии
13:12 Свой пример с применением шаблона
27:55 Разбираем второй пример применения паттерна Декоратор
*
★ Автор: Дмитрий Афанасьев.
★ Канал: clck.ru/JVYct
*
► Выразить благодарность, поддержать донатом развитие канала.
★ www.tinkoff.ru/rm/afanasev.dm...
★ www.donationalerts.ru/r/dmitr...
*
► Еще интересные курсы:
★ Видеокурс по Laravel: clck.ru/JVYa2
★ Видеокурс по Git: clck.ru/JVYYm
★ Объяснение SOLID: clck.ru/JVYXq
★ Шаблоны проектирования: clck.ru/JVYX7
★ Структурные шаблоны проектирования: clck.ru/TVB9Y
★★★ Все курсы → clck.ru/JVYVd

Опубликовано:

 

23 июл 2024

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 121   
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Как вам шаблон, коллеги? Видео, кстати, теперь и в 2К доступно.
@alexcc333
@alexcc333 3 года назад
Как и все шаблоны со своим приколом)
@onlybestmusic4185
@onlybestmusic4185 3 года назад
Спасибо что услышал мое предложение по использованию примеров при объяснении паттернов. Время от времени пересматриваю для закрепления в голове и незабывания, вроде патерны знаешь но насколько же всё-таки приятно смотреть с примерами :) хотения и терпения тебе
@awsdevbackend1783
@awsdevbackend1783 3 года назад
Очень много кода. Я понимаю, что это характерно для данного шаблона, но всегда подмывает пойти более простым пусть и не совсем правильным путем и решить все просто при помощи большого количества условий)
@sashasss7114
@sashasss7114 3 года назад
Дмитрий, добрый день. Можете сделать актуальное видео по работе с WebSocket-ами?
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Возьму на заметку 👍
@eaglesm1993
@eaglesm1993 3 года назад
Вот это заморочился, спасибо, было интересно и полезно)
@topalek
@topalek 3 года назад
Дмитрий, спасибо вам за вашу работу
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
🙏
@user-qq2in3lh1i
@user-qq2in3lh1i Год назад
Спасибо огромное ! Все понятно - и по полочкам разложено !
@DrTopk
@DrTopk 3 года назад
спасибо за твои видео!
@shnircourier
@shnircourier 3 года назад
спасибо за видео
@borisoffdenis
@borisoffdenis 3 года назад
Дмитрий крут!
@nlookorg
@nlookorg 2 года назад
Хорошая подача
@tiikhomirovilia6070
@tiikhomirovilia6070 2 года назад
Thank You!
@user-dg3vy5cq6k
@user-dg3vy5cq6k 3 года назад
Я пришел с курса Эксперn PHP, почти закончил, видимо поверил в себя! Ребята старый смарти рулит!
@ithandbook
@ithandbook 3 года назад
Спасибо! Классное видео! По поводу интриги у меня два предположения: 1. Возможно что-то не то с методом actionMain(), который в свою очередь запускает метод run() декораторов и основного декорируемого класса. У меня получилась такая несимметричная матрёшка, когда я переопределил методы actionBefore, actionMain и actionAfter во всех декораторах: [2021-03-28 16:14:36] local.INFO: Decorator [2021-03-28 16:14:36] local.INFO: Notify managers before [2021-03-28 16:14:36] local.INFO: Notify managers immediately before calling run() action [2021-03-28 16:14:36] local.INFO: Notify users before [2021-03-28 16:14:36] local.INFO: Notify users immediately before calling run() action [2021-03-28 16:14:36] local.INFO: Log Before [2021-03-28 16:14:36] local.INFO: Log immediately before calling run() action [2021-03-28 16:14:36] local.INFO: Base update [2021-03-28 16:14:36] local.INFO: Log After [2021-03-28 16:14:36] local.INFO: Notify users after [2021-03-28 16:14:36] local.INFO: Notify managers after Не скажу, что это прям ошибка, но если бы сообщения с "run()" были бы рядом с "Base update", было бы красивее:) 2. Возможно что-то с наследованием? У Вас свернута папочка "Inheritance" в каталоге с паттерном и Вы не показывали, что в ней:))
@nickfist9187
@nickfist9187 3 года назад
Спасибо за Вашу работу! Смотрится легко. Вопрос: планируете ли Вы добавить в курс "Laravel" аутентификацию и авторизацию пользователей?
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Будет отдельным миникурсом
@dimitro.cardellini
@dimitro.cardellini 3 года назад
1. Классное видео -- посмотрю предыдущие. 2. С ошибкой -- интгрига ...! ) Круто У меня вот есть вопрос к АбстрактДекоратору, а именно: - разбиение обертки на actionBefore, mainAction, actionAfter конечно, экономит на расширении декораторов, но оно провоцирует на добавление в декоратор мутируемого состояния: в actionBefore что-то считаем, записываем в контекст (он же this), потом в mainAction -- это читаем, принимаем решения тоже что-то считаем и тоже скорее всего что-то запишем, чтобы потом в actionAfter что-то вывести. Хотя по факту, если бы мы все сделали в переопределенном методе run, то контекст бы не понадобился. Я не о том, что все надо писать в одном методе, -- конечно же, внутри конерктного декоратора все надо декомпозировать в соответствии с его семантикой так, чтобы переопределенный метод run было легко прочитать. Сейчас это все выглядит, как экономия на "this->decoratedObject->run($order, $orderData)". В итоге все выльется, либо в то, что наследники будут переопределять mainAction точно так же, как они бы переопределяли сам метод run (тогда почему бы так не сделать сразу), либо будет использоваться мутрируемое состояние экземпляра декоратора, либо ... и то, и другое сразу. Лучше в абстрактном декораторе ограничиться только конструктором. И да, определения в англоязыной вики немного другие -- имеет смысл их тоже принимать во внимание.
@diatm1506
@diatm1506 9 месяцев назад
А чем этот декоратор отличается например от реализации в typescript или java? @decorator
@ant3413
@ant3413 3 года назад
будут ли примеры взаимодействие с Vue?
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Да
@user-et2cn3is9y
@user-et2cn3is9y 8 месяцев назад
Уффф...последние три паттерна, смысл то понятен. Словами на котиках могу объяснить и даже словами на примерах из реальных кейсов разработки. Но написать самому код...не смогу, все-таки опыта пока не хватает.
@romankovin8566
@romankovin8566 3 года назад
Большая просьба в видео раскрывать в дереве проекта те папки в которых лежат файлы. Поможет определить общий объем темы, сколько классов будет создано, сколько интерфейсов и т.д.
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Да вроде всегда показываю всю используемую иерархию...
@MrUndeadline
@MrUndeadline 3 года назад
На примере какой нить игры, где нужно сотне разных противников под общим интерфейсом добавить какое то поведение, очень накладно создавать еще 100 подклассов для добавления строчки кода
@user-wu7mg1cu4e
@user-wu7mg1cu4e Год назад
вот-вот, для других целей, они и не нужны
@enmaboya
@enmaboya 2 года назад
так что за ошибка то была в итоге?
@ardixq
@ardixq 2 года назад
А можно где то взять этот код, что б самому посмотреть?
@DmitryAfanasyev
@DmitryAfanasyev 2 года назад
Код не выкладываю. Вредит обучению. Надо руками набирать самому.
@alicenNorwood
@alicenNorwood 3 года назад
Великолепный паттерн, надёжный, блять, как швейцарские часы
@alicenNorwood
@alicenNorwood 3 года назад
Не туда написал, это к компоновщику
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Прочел голосом Гоблина 😁
@alicenNorwood
@alicenNorwood 3 года назад
@@DmitryAfanasyev написал голосом Гоблина
@alexanderk8992
@alexanderk8992 3 года назад
Есть ли какая-то репа с кодом уроков?
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Отсутствует
@alexanderk8992
@alexanderk8992 3 года назад
@@DmitryAfanasyev печально
@alexanderk8992
@alexanderk8992 3 года назад
Интрига заключалась как раз в дто?) Думаю, стоит записать видосы про дто вэлью обжект и основы ооп
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Нет, не в дто
@alexanderk8992
@alexanderk8992 3 года назад
@@DmitryAfanasyev ну, получилось, что так. Кстати, не думал замутить подкаст не с уроками, а где будешь приглашать гостей поговорить про код и программирование?
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Типа айтиБорода? Не думал о таком формате.
@alexanderk8992
@alexanderk8992 3 года назад
@@DmitryAfanasyev ну, более неофициально. Собираются челы и говорят о чем-то. Можно по темам или просто об айти в целом. Как пойдет
@alexanderk8992
@alexanderk8992 3 года назад
Возникли два вопроса: 1. как в декоратор прокинуть объект логера? 2. почему ты в конфиге прописал классы без нэймспейсов?
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
В ларе ведь логгер из коробки - не надо прокидывать. Неймспейсы выше в секции use.
@alexanderk8992
@alexanderk8992 3 года назад
@@DmitryAfanasyev Почему не надо? а если нужно тест написать? Неймспейсы выше - это дичь, поскольку пользователи конфига могут не знать такую особенность, могут тупо забыть, лучше прописывать полностью в конфиге
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Напиши Тейлору про дичь нэймспейсов, а то он их тоже в конфигах вверху херачит.
@alexanderk8992
@alexanderk8992 3 года назад
@@DmitryAfanasyev а, то есть вверху кофига? тогда да, норм. не увидел в видосе, где именно use используется. поэтому и спросил про репу, чтобы более наглядно видеть код.
@viv81ster
@viv81ster Год назад
Немного непонятное описание потому что на ум сразу приходит Стратегия а не Декоратор Мы же должны расширить метод какого-то объедка а не просто объедок. А в описании вроде основная цель поцепить новое поведение конкретно объдку
@_LEXX_
@_LEXX_ 3 года назад
Не плохо, но как то криповато получается вложенность, new в new в new ... похоже на callback hell
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Так и есть. Можно неплохо так усложнить код.
@alexalex6643
@alexalex6643 2 года назад
я в своё время, как только начинал учить патерны, видел такую реализацию: $order = new Sugar(new Sugar(new Coffee()));
@DmitryAfanasyev
@DmitryAfanasyev 2 года назад
Роберт Мартин против такого.
@onlybestmusic4185
@onlybestmusic4185 3 года назад
В глаза бросаются две проблемы 1) $orderData передаётся массивом, целостность массива ничем не гарантируется, нужен какой-то вэлуе обжект или dtо (кстати можно отдельное видео сделать и в нём объединить простой патерн DTO и как его правильно использовать в ларавеле и передавать между слоями и так далее. Есть интересное видео по использованию DTО в symfony, но там на аннотациях завязано, так бесит...) 2) в конфиге нет порядка выполнения, кто-то случайно поменяет порядок или вставит свою запись где-то в верх или в середину и вся логика декоратора пойдёт по бороде. Надо вводить жёсткий порядок выполнения и сортировать коллекцию по этому порядку а уже потом производить все эти декорирования.
@user-lk1fw1lp8b
@user-lk1fw1lp8b 3 года назад
DTO это анти-паттерн
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
1) почему? Пруфлинк в студию 2) синглтон антипаттерн, и?.
@user-lk1fw1lp8b
@user-lk1fw1lp8b 3 года назад
@@DmitryAfanasyev 1. Попытаюсь объяснить своими словами: ДТО полностью ломают инкапсуляцию, т к являются просто контейнерами данных и позволяют им(данным) свободно утекать в другие части программы. Они не самодостаточны 2. Синглтон антипаттерн, и поэтому мы не должны его использовать. Его следует знать как то, что необходимо избегать
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Надо Тейлору написать, а он в ларавеле внедрил и оптимизировал создание синглтонов. Не разбирается наверное в шаблонах.
@DmitryAfanasyev
@DmitryAfanasyev 3 года назад
Про дто не понял объяснения.
@alexalex6643
@alexalex6643 2 года назад
самая большая проблема с порядком выполнения. В вашем примере нельзя просто сначала например залогироватьДО, потом написать юзеру, потом залогировать после, если мы делаем что-то типа $logger($user($entity)) проблема №2, как по мне прекрасно описана в том же рефакториг гуру, где он описывал read/write данных. Там если не знать, какой цепочкой данные в декоратор собрались(допустим, что это красиво настраивается через UI гдето, и, внезапно, программистский баг, и таблица настроек слетает), непонятно будет, как потом исходный поток байт развернуть. И опять же, проблема 1, надо в нужной последовательности развернуть данные
@vitall789
@vitall789 Год назад
Мне кажется использовать методом стека может быть не оптимально! Лучше написать каждый декоратор под свою задачу, при создании декоратора передавая параметры объектов к примеру "logger"... если это нужно.
@romanbush5164
@romanbush5164 Год назад
Лол в питоне и с# это делать проще
Далее
Smart Sigma Kid #funny #sigma #comedy
00:26
Просмотров 6 млн
Декоратор с параметрами
19:39
Просмотров 9 тыс.
Паттерн Декоратор
20:33
Просмотров 30 тыс.
Чего ожидать от HTTP/3 + Go
51:07
Просмотров 3,6 тыс.