Template Method Pattern - Design Patterns (ep 13)

Поділитися
Вставка
  • Опубліковано 19 лис 2017
  • Video series on Design Patterns for Object Oriented Languages. This time we look at the Template Method Pattern.
    💙 BUY MY BOOK:
    leanpub.com/the-object-orient...
    ► The playlist
    • Design Patterns in Obj...
    ► Head First: Design Patterns
    geni.us/nlbA6
    ► Design Patterns: Elements of Reusable Object-Oriented Software
    geni.us/PsXmo
    ► Show your support using Patreon :D
    patreon.christopherokhravi.com
    ► SOLID Design Principles
    • SOLID Design Principles
    • SOLID Design Principle...
    ► Products I recommend:
    geni.us/71ZXF

КОМЕНТАРІ • 123

  • @namanvaishnav4307
    @namanvaishnav4307 12 днів тому +3

    How someone can be relevant after 6 years!! Amazing!!

  • @SelimAjimi
    @SelimAjimi 6 років тому +29

    If I can tell you how much I appreciate the work you are doing... you will not believe me. Please continue and don't stop.

  • @delucabruno
    @delucabruno 6 років тому +17

    Please continue with this serie, your videos are awesome!

  • @JohnWayne-nc6yq
    @JohnWayne-nc6yq 6 років тому +2

    Youre amazing man, I wish you could be my academician for my patterns lecture. 2 Days later I got Final exam and I finally understood how do many design patters work. Thanks for all, I wanna meet you some day cause your energy is perfect.

  • @agustinchavez4836
    @agustinchavez4836 6 років тому +2

    Your videos are one of the coolest things I found on youtube. Every time they present a design pattern in my university I watch one of your videos. You came to Argentina. Thank you! (Sorry my english is bad)

  • @karimel-shindy9655
    @karimel-shindy9655 6 років тому +8

    Awesome, I really love your way of explaning things. BTW you helped me a lot to understand a lot of concepts and terms which helped me to pass the technical exam and interview of a new job.
    thanks a lot Christopher

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

    This was a fantastic lecture. The lecturers at my university could learn a thing or two from you about how to teach. Many thanks!

  • @rithikareddy2919
    @rithikareddy2919 6 років тому +5

    Your videos are amazing!! Thanks a lot! This series has helped me a lot in understanding Design Patterns! :D

  • @Defiguss
    @Defiguss Рік тому

    Thank you so much for your amazing work! Really has helped me to grasp the concept of design patterns and see how useful they are. Thanks to you, my code became cleaner, more universal and more efficient. This is definitely the best design-patterns-explaining channel I have come across.

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

    Man you are Genius just when i was thinking this look similar to Strategy pattern you covered that part just then.

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

    You are the man, I've never looked forward to a lecture before

  • @nicolabombace2004
    @nicolabombace2004 6 років тому

    I totally agree with your point about the Strategy Pattern! very well explained

  • @MyroslavOhorodnyk
    @MyroslavOhorodnyk 4 роки тому +1

    This one was pretty complex for me up until the code example. Thanks for adding that one!
    And as always thanks!

  • @kasozivincent107
    @kasozivincent107 4 роки тому +1

    I love your accent. In addition you are my hero when it comes to design patterns

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

    Appreciate your efforts for providing this quality content !

  • @chamroeunuon4446
    @chamroeunuon4446 6 років тому +4

    Thank Christopher for creating this tutorial. It's make me more understand about design patterns: )

  • @kevinbenavides92
    @kevinbenavides92 6 років тому

    Thanks Chris! Keep up the great work.

  • @saudnaeem
    @saudnaeem 6 років тому +4

    Excellent explanation, helped a lot. thanks btw

  • @mikhailbisserov8017
    @mikhailbisserov8017 6 років тому +9

    Kudos for pointing out that Template Method is a good case of Open/Closed principle usage. My understanding is that in ASP NET WebForms they use Template Method so that developer could hook his code into page life cycle, because developer inherits his code-behind class from base Page class there. Even though they call it "events", developer doesn't have to use events subscription mechanism. But developer doesn't have to add "override" either. Ok, I'm not sure if that's canonical Template Method pattern in action.

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

    you are the best who explain design pattern , thank you man ......

  • @harishankar-cz9tx
    @harishankar-cz9tx 2 роки тому

    I use "Ruby On Rails" on daily basis. Didn't know it's very neat use of Template Method Pattern. Thanks :)

  • @mangeshphanse2132
    @mangeshphanse2132 5 років тому

    Very good video. Cleared the concept of template method. Keep it up

  • @sv6562
    @sv6562 Рік тому

    Awesome very clearly explained and great to use a board to explain

  • @marceloleoncaceres6826
    @marceloleoncaceres6826 9 місяців тому

    Another great video, thanks for sharing

  • @dhinahappybank1377
    @dhinahappybank1377 6 років тому

    Good Job, Chris! Thanks!

  • @claudiocito9057
    @claudiocito9057 5 років тому

    thank you so much, this videos are so helpful!!

  • @LavGupta08
    @LavGupta08 6 років тому +1

    Awesome video. Thank you so much again :)

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

    I have been using this one for years without even knowing it

  • @meratube007
    @meratube007 6 років тому

    like your passion for teaching !! thanks :)

  • @vahabghadiri
    @vahabghadiri 4 роки тому +1

    That was absolutely awesome!!!! VERY VERY THANKS! p.s. i am eagerly waiting for your UML basics or maybe tips video.

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

    Amazing explanation. Hats off to you...

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

    Great video! Thanks very much!

  • @Timboson
    @Timboson 4 роки тому

    Awesome explanation. You are my hero

  • @onkarvidhate1564
    @onkarvidhate1564 10 місяців тому

    in the definition of template pattern, they have used word "operation" because 'operation' term is equivalent to class method. And because we are only templating a method and not a whole class, author might have thought to emphasis more on it.

  • @ricardcutzh
    @ricardcutzh 5 років тому

    nice explanation dude! thanks a lot!

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

    I remember using this pattern (without knowing it's name) a while back while making a tweening system. The abstract tweening class had a method that calculated a 0-1 clamped value along a curve, and then called an abstract method for concrete tweens to implement using that clamped value as a parameter. In the end each concrete tween had a simple Evaluate(float t); to control animation. It worked great!
    Great tutorial series by the way! You are a great teacher :)

  • @santiagolosa4751
    @santiagolosa4751 6 років тому

    Super usefull thank you so much!

  • @bouchradahamni9881
    @bouchradahamni9881 5 років тому

    great explication !!!

  • @Endomorphism
    @Endomorphism 4 роки тому

    23:27 we can even use strategy pattern an other way
    inject strategy and Template Method will call
    *strategy.DoOperationsInSteps(this)*
    it admire composition over inheritance.

  • @AndreiMeius
    @AndreiMeius 4 роки тому +2

    The whole point of this pattern is to be able to do Record r = new User; r->save(); so records are uniformely treated. User u = new User doesn't show the power of the pattern.

  • @abdeltube772
    @abdeltube772 6 років тому +2

    It must has taken a lot of effort to prepare and edit the video, thank you!

  • @munjal55555
    @munjal55555 4 роки тому

    really nice explanation about strategy vs template

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

    awesome!

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

    Good Job!!!

  • @unknow8819
    @unknow8819 5 років тому

    Thank You, you saved my exam

  • @aymanshaawat
    @aymanshaawat 6 років тому

    Like before watching
    I was waiting for this pattern

  • @Cmppayne26542
    @Cmppayne26542 6 років тому

    I hope that in the future you will cover all patters from the GoF instead of just the ones covered in the heads first book

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

    Thank you!

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

    Thank you so much

  • @ShubhamGupta3110
    @ShubhamGupta3110 6 років тому

    Can you share some detailed thoughts on "Composition over Inheritance". Just a thought, can't we do what template pattern does using Decorator and Strategy if I am sticking to Composition over inheritance principle. Though I think it would be asking too much from the end user to use features of Abstract Class (used in your example.)

  • @deathangel908
    @deathangel908 6 років тому +2

    A good example of template pattern would be any lifecycle component.
    e.g. reactjs component or android component where frameworks calls lifecycle hooks like `onCreate` `onDestroy`. Also I guess most of this use cases break single responsibility principles. As your `User` model is responsible for holding data and saving it.
    38:40 good use of `trim`

  • @kevinshi8117
    @kevinshi8117 6 років тому

    brilliant!

  • @Ranjith_P
    @Ranjith_P 5 років тому

    Firstly Thanks for your videos they are amazing to clear concepts up .
    I am actually from Database background and learning Object oriented programming ( Java mostly ) out of interest . One question I had - what is this virtual keyword mentioned in the concept of hooks while implementing the Template method pattern ?

  • @bragoen
    @bragoen 6 років тому +3

    The funny thing is that when I learned about abstract classes in my very junior days, I thought they were meant for that very reason, provide base implementations and hooks. Then I learned about this pattern and I was like "wait, isn't it obvious?"

    • @ChristopherOkhravi
      @ChristopherOkhravi  6 років тому +2

      Hehe :) In some sense it indeed is. And in some sense I guess one could argue that all of the GoF design patterns are more or less obvious ideas that anyone who carefully contemplates OO will come up with on their own. But whether these ideas were then given names so that we can more easily talk about them or so that authors can sell more books I do not know :) :) Thanks for watching and for sharing! Interesting and relevant perspective.

    • @bragoen
      @bragoen 6 років тому

      Oh absolutely, a big part of pattern usefulness is to create a common language to share ideas of design (or make money), but still they're also a way of teaching usage and put some structure for those who are lost in the big mess of possibilities that is an OO language. Everyone is different but when I learned about those around Y2K this one was basically the only one where I sort of had made gotten the idea of "wait, is there any other way ?"

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

      @@ChristopherOkhravi Yeah I think everyone at some point has accidentally reinvented a design pattern before they knew what a design pattern was

  • @_aibeats
    @_aibeats 5 років тому

    I believe this pattern can be implemented without inheritance! Anyway, your videos are great.

  • @oleksandr.pastukhov
    @oleksandr.pastukhov 6 років тому +3

    Well done, Christopher! As always! BTW, do you plan to continue your series of videos about the books you have finished to read?

    • @ChristopherOkhravi
      @ChristopherOkhravi  6 років тому

      Thank you :) Much appreciated :) Do you mean the videos on non-programming books?

    • @oleksandr.pastukhov
      @oleksandr.pastukhov 6 років тому

      Christopher Okhravi yes, this is exactly what I meant.

  • @sushmap8844
    @sushmap8844 5 років тому

    marking save() method as final makes more consistent .

  • @alecc8231
    @alecc8231 4 роки тому +4

    Template pattern could be substituted with a Strategy:
    A class "A", which implements a 'Template()' method only, and has a dependency on other classes that are needed in that method. They would implement "INeededOperations".
    So the usage would be:
    INeededOperations neededOps1 = new ConcteteOperations1(); //Needed by class A operations implemented.
    object a = new A(INeededOperations); //dependency injected with needed operations.
    a.Template(); //actual method called, which used to be an abstract template method.
    This way, only Class A is there and no other variations of class A exist because we need to use the 'Template()' method. But multiple variations of the INeededOperations are implemented.
    Instead of the abstract class using ghost functions, this way 'real' injected functions would be used.
    By the way, I totally love these series.
    Way to go Christopher!

  • @B-Billy
    @B-Billy 6 років тому

    "HERO POSTER" haha... I like it :)

  • @CarlosGonzalezRubio
    @CarlosGonzalezRubio 6 років тому +3

    If possible I would like to see a video of the design pattern called mediator. Thanks for sharing your knowledge!

    • @ChristopherOkhravi
      @ChristopherOkhravi  6 років тому +2

      It will absolutely come :) If I would guess I would however say that it probably drops after New Years rather than before. But I hope that doesn’t cause any troubles for you 🙂🙂 Thanks for the encouragement!

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

      @@ChristopherOkhravi Did we add this? What is the name of the video title if it's part of this playlist?

  • @p...p
    @p...p 6 років тому

    hook method and method overriding are the same term that you are referring to or they are different things ?

  • @ganeshkumbhar2499
    @ganeshkumbhar2499 6 років тому +1

    Can we say Template pattern lies in between bridge pattern and strategy pattern, in terms of coupling?

  • @amank2410
    @amank2410 6 років тому +3

    Excellent :) .....

  • @divyeshkumarbalar7732
    @divyeshkumarbalar7732 5 років тому

    can you explain dependency injection concept in a separate video please....

  • @SunggukLim
    @SunggukLim 6 років тому +4

    Nice video as always(especially very good example!) :) btw, do you have podcast channel?

  • @m.alexander3071
    @m.alexander3071 5 років тому

    Do I get that right? Hmmm... The Strategy pattern abstracts over different algorithms that have a somewhat same behaviors but (possibly) strongly different structure (I think about sort algorthms "bubble sort" vs. "sorting networks"). The TemplateMethod Pattern would more for a specifically structured algorithm, that have only view portions different - like... a bubblesort where you templatized the type and the type specific swap of the things that are sorted.

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

    Great

  • @abhishekbansal9472
    @abhishekbansal9472 Рік тому

    How is this different from a simple abstract class or an interface?

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

    Regarding differences between Bridge and Strategy, isn't it that in Bridge, the Implementor part is more like Value Objects, whereas Strategy works with services/algorithms? I am just learning about patterns these days so it might be pretty dumb what I just said.

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

    24:00 I think I agree, that composition should be favored over inheritance, but I have a question regarding this case.
    In a scenario where we want to use Template Method Pattern, but we want to have the ConcreteClass inherit from say class Animal, couldn't we just let AbstractClass inherit from Animal and then ConcreteClass inherit from AbstractClass as usual, or is that problematic? (This is regarding the "spot for inheritance" 24:36)
    I understand that composition can be used way more freely than inheritance in languages that do not support multiple inheritance (like Java), but at least for the Template Method Pattern, I don't yet see how letting AbstractClass inherit from the Class you wanted ConcreteClass to inherit from is an issue.
    Also it feels like there should be a way to have something like the Template Method Pattern in interfaces that isn't a Startegy Pattern, but I can't really think of it right now...
    Awesome video btw, much support :)

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

    Can we say the bridge method is a generalization of the Template Method?

  • @Gusse1234554321
    @Gusse1234554321 4 роки тому

    22:24 Ahaha love it!

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

    2:18 Cracked me "This is aah"

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

    Become teacher on UDEMY and let others understand the patterns. I would be the first to buy the course.

  • @benjamincisneros797
    @benjamincisneros797 6 років тому +1

    I like the way you explain the design patterns. Just a suggestion, you can use {A} for abstract classes and methods instead of italics or other styles as UML for Java programmers book suggests. By Robert C. Martin.

    • @ChristopherOkhravi
      @ChristopherOkhravi  6 років тому +1

      Thank you for the great suggestion! Not sure what I was thinking when I tried to write in italics :D

    • @kareemjeiroudi1964
      @kareemjeiroudi1964 4 роки тому

      @@ChristopherOkhravi Handwritten italics 😅

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

    Simple application of template method pattern is in Instagram where template is the same but content(image, reel, etc) are different.
    PS: This is just an example.

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

    few things are misleading/wrong, In strategy pattern behavior is injected in run time, i.e. the iAlogo's Concrete class has a behavior; whereas in template method a template is extended to get a new behavior at the compile time.

  • @lazarbecic2199
    @lazarbecic2199 Рік тому

    22:20 Nice bonk XD

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

    Thank you, Christopher! I have one question though, does the template method violate SRP actually?

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

      I guess not if you think about the responsibility of the template method as "organise the structure of the algorithm correctly". Which I guess comes back the whole discussion about when the template method would be an appropriate pattern - it only makes sense if the algorithm has a predefined structure which has to be preserved. At least, that's how I see it.

  • @nitin_puranik
    @nitin_puranik 10 місяців тому

    Chris, the subtitles (cc) in this video is being detected as Dutch. Could you please change the cc setting to English so that non native English speakers can follow along better? I think it must be a simple setting in your UA-cam studio. Thanks!

  • @SalahLFC11
    @SalahLFC11 4 роки тому +2

    "Template method defines skeleton of algorithm in an operation" I think here opration = method. I heard these words interchangably in my classes.

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

    I'm not getting the whole "hook" aspect. Why would you have a concrete method that's empty? If the sub class doesn't override the empty hook method, you have no implementation anywhere that's ran. What's that point of calling the hook method from the templateMethod() if the hook method may never provide any behavior? Wouldn't templateMethod() have to check if an implemented hook method somewhere, did something.

  • @divyeshkumarbalar7732
    @divyeshkumarbalar7732 5 років тому +4

    I have a very bad habit of watching videos at 2xSpeed; and while watching, it seems like you are having strokes..... joke a part..
    Good job, keep it up

  • @ashwingaikwad128
    @ashwingaikwad128 5 років тому +4

    17:55 uuuaahh :P :P

  • @timothy6966
    @timothy6966 5 років тому

    Funny. I’ve been building a way to run optimizations on models where exact implementations could vary. I thought I was using the strategy pattern, like a boss, turns out I created a template function letter by letter. Including the lifecycle hooks. The more I learn about design patterns, the more I realize it’s all just common sense. If you understand object orient programming - *really* understand - you know design patterns.

  • @ameeralikhan9288
    @ameeralikhan9288 4 роки тому +2

    Please cover Chain of responsibility pattern i have tough time understanding it only you can help :)
    Also Mediator, Visitor and Memento please

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

    Never read about the Template Pattern, but the moment Chris read the definition I paused the video for a minute to think and came up with the exact uml diagram and the code. The rest of the video was just like reinforcing my idea...guess I am really good at this stuff

  • @momedalhouma14
    @momedalhouma14 5 років тому +3

    what it remains: chain of responsability, Command, Interpreter, Mediator, Memonto, Visitor design patterns. please please please.

    • @GabrielVasile
      @GabrielVasile 5 років тому

      Command is already done. You can find it here ua-cam.com/video/9qA5kw8dcSU/v-deo.html

  • @umutozkan
    @umutozkan 5 років тому

    Good conceptual info but you can find better real time example.

  • @kevinchun7058
    @kevinchun7058 4 роки тому +1

    Don't call me, I will call you.

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

    Huh, here’s a pattern I’ve used without knowing it.

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

    HoF, functional programming is so much simpler...

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

      Paterns exist also in functional programming. Doesn't matter if is an object or function . Also you need sometimes use inheritence

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

    1k likes :)

  • @kevintyrrell7409
    @kevintyrrell7409 6 років тому +7

    Really on the long side man. I feel like the design pattern could be expressed much more succinctly. For example on Singleton, I could say that the theory is having only one object instantiated at a time. That in multithreaded applications it becomes harder. Then speak of when it should be used and why not. Then at the end show a tiny bit of UML and pseudocode. Just my two cents

    • @ChristopherOkhravi
      @ChristopherOkhravi  6 років тому +2

      Super good two cents. Much appreciated :) I need to learn to control my ramblings and rants :) Thanks for watching and for the feedback 🙏 😊

    • @oceanhugstheshore
      @oceanhugstheshore 6 років тому +13

      I disagree. Short explanations omit a lot of underlying concepts and personally I find it great, that Chistopher describes the patterns clearly and in details. I also like the fact, that the most important ideas are repeated several times during the video, as it helps to remember better.
      Christopher, thank you for these great videos, they're so much better than our university lectures! :)

    • @iLight33r
      @iLight33r 5 років тому

      @@oceanhugstheshore Agreed!

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

    rule1 of software developer. It's never going to change= next week will change

  • @boblim623
    @boblim623 4 місяці тому

    learn English and learn Design Patterns. thx from China

  • @soorathea
    @soorathea Рік тому

    All your other vids are good, but this one too wordy so plz start at 42:00

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

    Captain Jack Sparrow.!! 😉😂

  • @Isuri
    @Isuri 5 років тому +2

    Your videos are amazing but I wish you would just compress them a tiny bit... I feel like you could just be more efficient and clear. By the time I finish though, it's really clear. I just need to cram for exams and 50mins even at 2x the speed is a lot of time :p

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

    I should pay you instead of uni