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

Поділитися
Вставка
  • Опубліковано 1 жов 2024

КОМЕНТАРІ • 121

  • @DmitryAfanasyev
    @DmitryAfanasyev  3 роки тому +17

    Как вам шаблон, коллеги? Видео, кстати, теперь и в 2К доступно.

    • @alexcc333
      @alexcc333 3 роки тому

      Как и все шаблоны со своим приколом)

    • @onlybestmusic4185
      @onlybestmusic4185 3 роки тому +4

      Спасибо что услышал мое предложение по использованию примеров при объяснении паттернов. Время от времени пересматриваю для закрепления в голове и незабывания, вроде патерны знаешь но насколько же всё-таки приятно смотреть с примерами :) хотения и терпения тебе

    • @awsdevbackend1783
      @awsdevbackend1783 3 роки тому

      Очень много кода. Я понимаю, что это характерно для данного шаблона, но всегда подмывает пойти более простым пусть и не совсем правильным путем и решить все просто при помощи большого количества условий)

    • @sashasss7114
      @sashasss7114 3 роки тому

      Дмитрий, добрый день. Можете сделать актуальное видео по работе с WebSocket-ами?

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому

      Возьму на заметку 👍

  • @eaglesm1993
    @eaglesm1993 3 роки тому +3

    Вот это заморочился, спасибо, было интересно и полезно)

  • @enmaboya
    @enmaboya 3 роки тому +1

    так что за ошибка то была в итоге?

  • @nickfist9187
    @nickfist9187 3 роки тому +2

    Спасибо за Вашу работу! Смотрится легко. Вопрос: планируете ли Вы добавить в курс "Laravel" аутентификацию и авторизацию пользователей?

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому +2

      Будет отдельным миникурсом

  • @alicenNorwood
    @alicenNorwood 3 роки тому +2

    Великолепный паттерн, надёжный, блять, как швейцарские часы

    • @alicenNorwood
      @alicenNorwood 3 роки тому +1

      Не туда написал, это к компоновщику

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому +4

      Прочел голосом Гоблина 😁

    • @alicenNorwood
      @alicenNorwood 3 роки тому +5

      @@DmitryAfanasyev написал голосом Гоблина

  • @diatm1506
    @diatm1506 11 місяців тому

    А чем этот декоратор отличается например от реализации в typescript или java? @decorator

  • @romanbush5164
    @romanbush5164 2 роки тому +1

    Лол в питоне и с# это делать проще

  • @viv81ster
    @viv81ster 2 роки тому

    Немного непонятное описание потому что на ум сразу приходит Стратегия а не Декоратор
    Мы же должны расширить метод какого-то объедка а не просто объедок.
    А в описании вроде основная цель поцепить новое поведение конкретно объдку

  • @dimitro.cardellini
    @dimitro.cardellini 3 роки тому

    1. Классное видео -- посмотрю предыдущие.
    2. С ошибкой -- интгрига ...! ) Круто
    У меня вот есть вопрос к АбстрактДекоратору, а именно:
    - разбиение обертки на actionBefore, mainAction, actionAfter конечно, экономит на расширении декораторов, но оно провоцирует на добавление в декоратор мутируемого состояния: в actionBefore что-то считаем, записываем в контекст (он же this), потом в mainAction -- это читаем, принимаем решения тоже что-то считаем и тоже скорее всего что-то запишем, чтобы потом в actionAfter что-то вывести. Хотя по факту, если бы мы все сделали в переопределенном методе run, то контекст бы не понадобился. Я не о том, что все надо писать в одном методе, -- конечно же, внутри конерктного декоратора все надо декомпозировать в соответствии с его семантикой так, чтобы переопределенный метод run было легко прочитать. Сейчас это все выглядит, как экономия на "this->decoratedObject->run($order, $orderData)". В итоге все выльется, либо в то, что наследники будут переопределять mainAction точно так же, как они бы переопределяли сам метод run (тогда почему бы так не сделать сразу), либо будет использоваться мутрируемое состояние экземпляра декоратора, либо ... и то, и другое сразу.
    Лучше в абстрактном декораторе ограничиться только конструктором.
    И да, определения в англоязыной вики немного другие -- имеет смысл их тоже принимать во внимание.

  • @ВячеславКомков-ъ1д
    @ВячеславКомков-ъ1д 10 місяців тому

    Уффф...последние три паттерна, смысл то понятен. Словами на котиках могу объяснить и даже словами на примерах из реальных кейсов разработки. Но написать самому код...не смогу, все-таки опыта пока не хватает.

  • @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" в каталоге с паттерном и Вы не показывали, что в ней:))

  • @borisoffdenis
    @borisoffdenis 3 роки тому +1

    Дмитрий крут!

  • @ИгорьСоколов-ц7п
    @ИгорьСоколов-ц7п 3 роки тому

    Я пришел с курса Эксперn PHP, почти закончил, видимо поверил в себя! Ребята старый смарти рулит!

  • @topalek
    @topalek 3 роки тому +2

    Дмитрий, спасибо вам за вашу работу

  • @_LEXX_
    @_LEXX_ 3 роки тому

    Не плохо, но как то криповато получается вложенность, new в new в new ... похоже на callback hell

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому +1

      Так и есть. Можно неплохо так усложнить код.

    • @alexalex6643
      @alexalex6643 3 роки тому

      я в своё время, как только начинал учить патерны, видел такую реализацию: $order = new Sugar(new Sugar(new Coffee()));

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому

      Роберт Мартин против такого.

  • @shnircourier
    @shnircourier 3 роки тому +1

    спасибо за видео

  • @onlybestmusic4185
    @onlybestmusic4185 3 роки тому +4

    В глаза бросаются две проблемы
    1) $orderData передаётся массивом, целостность массива ничем не гарантируется, нужен какой-то вэлуе обжект или dtо (кстати можно отдельное видео сделать и в нём объединить простой патерн DTO и как его правильно использовать в ларавеле и передавать между слоями и так далее. Есть интересное видео по использованию DTО в symfony, но там на аннотациях завязано, так бесит...)
    2) в конфиге нет порядка выполнения, кто-то случайно поменяет порядок или вставит свою запись где-то в верх или в середину и вся логика декоратора пойдёт по бороде.
    Надо вводить жёсткий порядок выполнения и сортировать коллекцию по этому порядку а уже потом производить все эти декорирования.

    • @МаксимГорюнов-м7и
      @МаксимГорюнов-м7и 3 роки тому

      DTO это анти-паттерн

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому +1

      1) почему? Пруфлинк в студию 2) синглтон антипаттерн, и?.

    • @МаксимГорюнов-м7и
      @МаксимГорюнов-м7и 3 роки тому

      @@DmitryAfanasyev 1. Попытаюсь объяснить своими словами: ДТО полностью ломают инкапсуляцию, т к являются просто контейнерами данных и позволяют им(данным) свободно утекать в другие части программы. Они не самодостаточны
      2. Синглтон антипаттерн, и поэтому мы не должны его использовать. Его следует знать как то, что необходимо избегать

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому

      Надо Тейлору написать, а он в ларавеле внедрил и оптимизировал создание синглтонов. Не разбирается наверное в шаблонах.

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому

      Про дто не понял объяснения.

  • @tiikhomirovilia6070
    @tiikhomirovilia6070 2 роки тому

    Thank You!

  • @MrUndeadline
    @MrUndeadline 3 роки тому

    На примере какой нить игры, где нужно сотне разных противников под общим интерфейсом добавить какое то поведение, очень накладно создавать еще 100 подклассов для добавления строчки кода

  • @romankovin8566
    @romankovin8566 3 роки тому

    Большая просьба в видео раскрывать в дереве проекта те папки в которых лежат файлы. Поможет определить общий объем темы, сколько классов будет создано, сколько интерфейсов и т.д.

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому

      Да вроде всегда показываю всю используемую иерархию...

  • @АлександраИванова-ц8ч

    Спасибо огромное ! Все понятно - и по полочкам разложено !

  • @ant3413
    @ant3413 3 роки тому

    будут ли примеры взаимодействие с Vue?

  • @ardixq
    @ardixq 2 роки тому

    А можно где то взять этот код, что б самому посмотреть?

    • @DmitryAfanasyev
      @DmitryAfanasyev  2 роки тому

      Код не выкладываю. Вредит обучению. Надо руками набирать самому.

  • @nlookorg
    @nlookorg 2 роки тому

    Хорошая подача

  • @DrTopk
    @DrTopk 3 роки тому

    спасибо за твои видео!

  • @alexanderk8992
    @alexanderk8992 3 роки тому

    Возникли два вопроса:
    1. как в декоратор прокинуть объект логера?
    2. почему ты в конфиге прописал классы без нэймспейсов?

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому +1

      В ларе ведь логгер из коробки - не надо прокидывать. Неймспейсы выше в секции use.

    • @alexanderk8992
      @alexanderk8992 3 роки тому

      @@DmitryAfanasyev Почему не надо? а если нужно тест написать? Неймспейсы выше - это дичь, поскольку пользователи конфига могут не знать такую особенность, могут тупо забыть, лучше прописывать полностью в конфиге

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому +2

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

    • @alexanderk8992
      @alexanderk8992 3 роки тому

      @@DmitryAfanasyev а, то есть вверху кофига? тогда да, норм. не увидел в видосе, где именно use используется. поэтому и спросил про репу, чтобы более наглядно видеть код.

  • @alexanderk8992
    @alexanderk8992 3 роки тому

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

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому

      Нет, не в дто

    • @alexanderk8992
      @alexanderk8992 3 роки тому

      @@DmitryAfanasyev ну, получилось, что так. Кстати, не думал замутить подкаст не с уроками, а где будешь приглашать гостей поговорить про код и программирование?

    • @DmitryAfanasyev
      @DmitryAfanasyev  3 роки тому

      Типа айтиБорода? Не думал о таком формате.

    • @alexanderk8992
      @alexanderk8992 3 роки тому

      @@DmitryAfanasyev ну, более неофициально. Собираются челы и говорят о чем-то. Можно по темам или просто об айти в целом. Как пойдет

  • @alexanderk8992
    @alexanderk8992 3 роки тому

    Есть ли какая-то репа с кодом уроков?

  • @alexalex6643
    @alexalex6643 3 роки тому +2

    самая большая проблема с порядком выполнения. В вашем примере нельзя просто сначала например залогироватьДО, потом написать юзеру, потом залогировать после, если мы делаем что-то типа $logger($user($entity))
    проблема №2, как по мне прекрасно описана в том же рефакториг гуру, где он описывал read/write данных. Там если не знать, какой цепочкой данные в декоратор собрались(допустим, что это красиво настраивается через UI гдето, и, внезапно, программистский баг, и таблица настроек слетает), непонятно будет, как потом исходный поток байт развернуть. И опять же, проблема 1, надо в нужной последовательности развернуть данные

    • @vitall789
      @vitall789 Рік тому +1

      Мне кажется использовать методом стека может быть не оптимально!
      Лучше написать каждый декоратор под свою задачу, при создании декоратора передавая параметры объектов к примеру "logger"... если это нужно.