Template Method Pattern - Design Patterns (ep 13)

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

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

  • @namanvaishnav4307
    @namanvaishnav4307 5 месяцев назад +7

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

  • @SelimAjimi
    @SelimAjimi 7 лет назад +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.

  • @UngodlyDev
    @UngodlyDev 29 дней назад

    This is the code smell of RUclips videos, I mean that but I’m also very grateful you took the time to share your understanding

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

    Used these videos 6 year back to clear exams... still use them as a reference at work!! Amazing content!!

  • @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)

  • @delucabruno
    @delucabruno 7 лет назад +17

    Please continue with this serie, your videos are awesome!

  • @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!

  • @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 :)

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

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

  • @JohnWayne-nc6yq
    @JohnWayne-nc6yq 7 лет назад +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.

  • @karimel-shindy9655
    @karimel-shindy9655 7 лет назад +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

  • @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 5 лет назад +3

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

  • @mikhailbisserov
    @mikhailbisserov 7 лет назад +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.

  • @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`

  • @kasozivincent107
    @kasozivincent107 4 года назад +1

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

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

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

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

    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.

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

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

  • @rithikareddy2919
    @rithikareddy2919 7 лет назад +5

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

  • @sv6562
    @sv6562 Год назад

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

  • @AndreiMeius
    @AndreiMeius 5 лет назад +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.

  • @MyroslavOhorodnyk
    @MyroslavOhorodnyk 5 лет назад +1

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

  • @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 :)

  • @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!

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

    Amazing explanation. Hats off to you...

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

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

  • @marceloleoncaceres6826
    @marceloleoncaceres6826 Год назад

    Another great video, thanks for sharing

  • @onkarvidhate1564
    @onkarvidhate1564 Год назад

    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.

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

    Appreciate your efforts for providing this quality content !

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

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

  • @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.

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

    Excellent explanation, helped a lot. thanks btw

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

    I want to see this guy code amazing explanation please make a video where you share some problems you have solved at your workplace

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

    Awesome explanation. You are my hero

  • @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 :)

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

    Thanks Chris! Keep up the great work.

  • @abdeltube772
    @abdeltube772 7 лет назад +2

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

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

    really nice explanation about strategy vs template

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

    Thank You, you saved my exam

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

    Great video! Thanks very much!

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

    Good Job, Chris! Thanks!

  • @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

  • @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.

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

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

    • @ChristopherOkhravi
      @ChristopherOkhravi  7 лет назад +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 4 года назад

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

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

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

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

    Good Job!!!

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

    Awesome video. Thank you so much again :)

  • @benjamincisneros797
    @benjamincisneros797 7 лет назад +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  7 лет назад +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 😅

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

    marking save() method as final makes more consistent .

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

    like your passion for teaching !! thanks :)

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

    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

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

    Like before watching
    I was waiting for this pattern

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

    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.)

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

    Thank you so much

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

    Thank you!

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

    great explication !!!

  • @oleksandr.pastukhov
    @oleksandr.pastukhov 7 лет назад +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  7 лет назад

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

    • @oleksandr.pastukhov
      @oleksandr.pastukhov 7 лет назад

      Christopher Okhravi yes, this is exactly what I meant.

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

    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

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

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

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

    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.

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

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

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

    nice explanation dude! thanks a lot!

  • @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.

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

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

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

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

  • @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.

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

    awesome!

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

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

  • @p...p
    @p...p 6 лет назад

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

  • @nitin_puranik
    @nitin_puranik Год назад

    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 RUclips studio. Thanks!

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

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

  • @aayushshrivastav7515
    @aayushshrivastav7515 15 дней назад

    Anyone thinking how before pointcuts might fit in? Would it be better or worse?

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

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

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

    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.

  • @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 ?

  • @kutanarcanakgul5533
    @kutanarcanakgul5533 5 лет назад +3

    2:18 Cracked me "This is aah"

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

    Super usefull thank you so much!

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

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

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

    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.

  • @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.

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

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

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

    Excellent :) .....

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

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

  • @lazarbecic2199
    @lazarbecic2199 Год назад

    22:20 Nice bonk XD

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

    brilliant!

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

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

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

    Great

  • @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

  • @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 ruclips.net/video/9qA5kw8dcSU/видео.html

  • @ashwingaikwad128
    @ashwingaikwad128 5 лет назад +4

    17:55 uuuaahh :P :P

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

    22:24 Ahaha love it!

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

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

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

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

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

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

  • @kevinchun7058
    @kevinchun7058 5 лет назад +1

    Don't call me, I will call you.

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

    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

  • @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

  • @kevintyrrell7409
    @kevintyrrell7409 7 лет назад +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  7 лет назад +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 6 лет назад

      @@oceanhugstheshore Agreed!

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

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