Difference Between Composite and Decorator Pattern - Design Patterns (ep 15)

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

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

  • @hfontanez98
    @hfontanez98 5 лет назад +20

    A list is still considered a hierarchical structure. It has a head (root), a tail (leaf), and potentially stuff in the middle. As you clearly stated, composite pattern is all about establishing the structure WITHOUT changing the underlying behavior of the component of the structure. Decorator is not about structure, but about changing (augmenting) the behavior of the component.
    Your example of decorator gave me an idea. In Rich Text Editors, text can be "decorated" with different styles like bolded, italicized, and underlined. It can also be decorated with color. It can also be decorated with font families. These decorations can be used in conjunction with each other. This sort of thing cannot (should not) be done using Composite Pattern.
    In the same context, Composite Pattern can be used to establish structures such as toolbars, menu bars, and even the document device context. This is important because (for instance) when you resize your Word Processor window, you will want to resize all of the children elements that belong to it (in order to keep the aspect ratio, for instance). This sort of functionality cannot (should not) be done with a Decorator Pattern.
    I think the confusion can be attributed in part (at least for me) to the fact that Decorator Pattern is categorized as a STRUCTURAL design pattern rather than BEHAVIORAL. I think this is a mistake because clearly the intent of the pattern is to add additional responsibilities (behaviors) to objects.

    • @lme918
      @lme918 4 года назад

      that was a good example! thanks.

  • @VinodKumar-pf1un
    @VinodKumar-pf1un Год назад +1

    Hi, thanks for sharing your thoughts :)
    Just one correction
    @1:26 "at runtime alter the behavior of some particular thing" aligns more closely with the Strategy pattern rather than the Decorator pattern. Decorator pattern is about extending or enhancing the behavior of individual objects in a flexible way without modifying/altering their original base classes.

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

    The exploration of tree structures in Composite and dynamic behavior modification in Decorator offers practical guidance for choosing the right pattern based on intent.

  • @Levendo
    @Levendo 4 года назад +4

    I didnt even realize the similarity between the two patterns before watching this video. Thanks man!

  • @Jewelrumble
    @Jewelrumble 6 лет назад +4

    I've often found decorator very useful in game development. Works great with temporary boosts, score and timer multipliers, upgrades. Your videos are excellent

  • @dp-bhatt
    @dp-bhatt 7 лет назад +5

    First time I understood the difference between Decorator and Composite design pattern super clearly. :) Thank you so much.

  • @anasfcb
    @anasfcb 7 лет назад +4

    Hey Christopher, Thanks a lot for "this kind" of videos, it allows us to complete and verify our understanding of the related specialized design pattern video. As you've mentionned (between the lines) it's only when you compare some similar design patterns that you start realizing that it's all about nuances.
    Please keep explaining the nuances in similar DP, it's just VERY helpful, and sincerely good luck in your PhD :)

  • @naturalsmen1
    @naturalsmen1 3 года назад

    I like the way you explain the differences between the two patterns using references pointing upwards or downwards. Great work!

  • @RaviYadav-jb3nf
    @RaviYadav-jb3nf 4 года назад

    As I understood from the example, in composite all nodes will have same logic based on input from child-nodes. Whereas, in decorator each decorator-node may apply different logic on output from child decorator/component.
    Is above correct?

  • @moawyahabdulrahman8782
    @moawyahabdulrahman8782 2 года назад +1

    I like to think of decorator pattern as just adding (multiple) small functionality(ies) to the core logic of my object.
    But in composite pattern I think of it as "composing" multiple distinct functionality where each functionality has it's on identity.
    the composite object should not add functionality, It should compose the functionality of other objects in some what. (maybe apply all the changes once, maybe apply them in order or what ever). unlike decorators which have 1 and only 1 additional job to add.

  • @codingdave
    @codingdave 3 года назад

    If I just could like the complete video series more than once...
    Excellent content Christopher!
    👍👍👍👍👍👍👍👍👍👍👍👍👍👍

  • @michor10
    @michor10 5 лет назад

    Excellent video, as always, Christopher. I'm really enjoying this series. It's to just sit back watch you take these patterns apart. Cheers!

  • @Ritesh91188
    @Ritesh91188 7 лет назад +6

    Chris, you are doing great work...Keep it up!! One request from my end.....Please make videos on system design(architecture with design patterns for parking lot, whatsapp, or any system) so it will be really helpful..............

    • @ChristopherOkhravi
      @ChristopherOkhravi  7 лет назад +1

      Thank you for watching and for your suggestion! Do you mean that you want more context? Like examples that are not just hypothetical but within a bigger context? Thank you again.

  • @josephfernando4867
    @josephfernando4867 7 лет назад +14

    Any particular reason for discussing differences ...are't they for completely different needs..composite for structure and decorator for adding functionality...Could you give similarities..that would be interesting.

  • @andriikukuruza6844
    @andriikukuruza6844 3 года назад

    Wow, it blew my mind!

  • @TomKazanskyPolakow
    @TomKazanskyPolakow 5 лет назад

    I find your reasoning very interesting.

  • @boblim623
    @boblim623 9 месяцев назад

    相同的是,装饰器与组合模式都继承并聚合抽象类(接口),但区别是,装饰器是抽象类,而组合composite是具象类
    The same thing is that both the decorator and composition patterns inherit and aggregate abstract classes (interfaces), but the difference is that the decorator is an abstract class, while the composite is a concrete class.

    • @boblim623
      @boblim623 9 месяцев назад

      装饰器是一对一,而组合模式一般都是一对多The decorator is one -to -one, and the combination mode is generally one to many

  • @utubeuser764
    @utubeuser764 5 лет назад

    great explanation

  • @vaneet0
    @vaneet0 4 года назад

    Really Awesome

  • @sthoyyeti
    @sthoyyeti 6 лет назад

    Good Example I can think of for Composite pattern: perform totalEmployees operation on LDAP tree from different levels say Org level, Business unit level, Section, Dept, Group, leaf returning zero.

  • @B-Billy
    @B-Billy 7 лет назад +2

    Hey Cris...
    Thanks for great work, however could you please create video on "Flyweight"

  • @kaustuvchatterjee4117
    @kaustuvchatterjee4117 2 года назад +1

    The basic definitions are the differences as you reiterated...Can following be the takeaway from this video?... Decorator is for applying multiple algorithm on single component... And Composite for applying single algorithm on multiple components(And subcomponents!!)... what do you say?

  • @robertczaja7151
    @robertczaja7151 7 лет назад +3

    Your Design Pattern series is really helpful! Despite I have a GoF book, when I want to check new pattern I watch your video first. Do you plan to cover patterns not presented in GoF book?

  • @michaelyahyaev6747
    @michaelyahyaev6747 2 года назад

    I really like your videos 🔥🔥🔥

  • @gigajoules6636
    @gigajoules6636 5 лет назад

    I guess you could use a decorator tree for some kind of layered damage system in a game?
    first branches could be body parts and then each split layer could be a different type of armour and then the branches from that are over-armour / buffs?
    Might be a bit explodey but hey.

  • @bessermt
    @bessermt 6 лет назад

    GoF shows 1 Decorator in the diagram. See the last page of the book for the Class Diagram Notation. Arrow with no dot = one.

  • @SelimAjimi
    @SelimAjimi 7 лет назад +1

    First and please continue sharing those videos ...

  • @henryjoe7853
    @henryjoe7853 6 лет назад

    Great video! could you do more of these nuances? There is even a similarity between composite and proxy. Also, there is some nuances between Adaptor and decorator e.t.c perhaps more of higher level nuances like presented in this video will help us more. Great work Christopher. I am now a fan :D

  • @angelrodriguez2259
    @angelrodriguez2259 5 лет назад

    Hi!
    Again, another great video.
    Could we say that another difference between patterns is that in Composite patterns the objective is that nodes have homogeneus functionalities while with the decorator we search for heterogeneus functionalities?
    Thanks a lot

  • @Apiday
    @Apiday 7 лет назад

    Tu gères poto!

  • @fotios4902
    @fotios4902 6 лет назад

    What about the difference between the actual nodes of the two Patterns? i.e. in Decorator every node behaves differently. That's something you explicitly noted in the Decorator video bringing the example of Inputstream, Bufferstream etc. While in the Composite they all behave the same. Right? BTW thanks for the great videos!

  • @iham1313
    @iham1313 4 года назад

    i love your vids - even they are a little aged (but who cares as it is about patterns, that are there for a long time) - but this time i can't follow
    Component is an interface -> IComponent that has two concrete implementations: Leaf and Composite - while Leaf has no further children the Composite does.
    otherwise the decorator pattern
    the Component is an interface too -> IComponent that has a concrete implementation: ConcreteComponent and an abstract class Decorator that has multiple ConcreteDecorators
    i sense difference here - beyond intend ;)

  • @obi-center
    @obi-center 6 лет назад +3

    Thanks, bro ! You have a beer, when we meet :)
    Regards,
    Aleksandar

  • @sweetteddy390
    @sweetteddy390 3 года назад

    Decorator that decorates the decorator that decorates the decorator that decorates the component 😀

  • @PoulJulle-wb9iu
    @PoulJulle-wb9iu 4 года назад

    if decorator must have a comp, its a composition not aggregation

  • @eskindirabebegeda713
    @eskindirabebegeda713 5 лет назад +2

    Highly decorated lecture. let the viewer go and see the specific patterns , you could have done an on point session with