Builder Design Pattern Explained in 10 Minutes

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

КОМЕНТАРІ • 71

  • @darienverdugo290
    @darienverdugo290 Рік тому +10

    At 6:43, this was like my lightbulb moment lol. Then, possibilities started coming to mind. Thanks so much; you just saved me a lot of time.

    • @kantancoding
      @kantancoding  10 місяців тому +1

      That’s awesome! Thanks for watching 😊

  • @marcouitendaal985
    @marcouitendaal985 5 місяців тому +3

    Thank you very much for a very straightforward and easy to understand explanation. I'm going to look at more of your content.

  • @khodjasmail2983
    @khodjasmail2983 10 днів тому

    We will be happy if you explain more design patterns

  • @ronboprime
    @ronboprime 7 місяців тому

    that was an easy explanation. I've been trying to figure this out, for a week now! lol. thanks dude! kudos!

    • @kantancoding
      @kantancoding  6 місяців тому

      That’s awesome! Thanks for watching 🙂

  • @rutujawattamwar5132
    @rutujawattamwar5132 Рік тому +5

    You just made this real easy to understand! Thank You.

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

      That’s great! I’m happy to help 😊

  • @Chronomatrix
    @Chronomatrix Рік тому +11

    How is this pattern better than using the constructor? Perhaps I've not yet seen a real case where this would make sense, maybe if we're dealing with really big constructors with a lot of parameters? Idk

    • @TJackson736
      @TJackson736 Рік тому +3

      It would be nice to have a complementary video showing why the pattern is useful.

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

      I can also see this as useful if the object's parameters are only given one at a time. You can then use build once all the necessary parameters are given.

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

      I explain why you might use this pattern in the video. Both points about many constructor params and building individual attributes of the object at different points that you both mention are explained in the video. Please watch the whole video 🙂

    • @Sobioytccc
      @Sobioytccc Рік тому +2

      This pattern comes to handy only when you understand the need. If you are concerned about why it is good replacement of constructors is that it strictly follows open close principle. Otherwise it’s all same tricks, it just saves you from modifying existing working class. I do not see other benefit. The client is happy that additional features didn’t interrupt writing flow.

    • @Javier_Corado
      @Javier_Corado 9 місяців тому +1

      For example I am working on a library for a communication protocol, I have to take multiple types of inputs and depending of those I need to build different type of messages, applying this made my code flexible because I decoupled creation from use and I was able to create different methods for different types of message objects. An alternative would be to create an abstract message class and have concrete implementations and use a factory method pattern, but due to the size of attributes I was repeating my self like crazy, that's why this pattern worked great for me in this case. This also comes in handy when working with protobuffs.

  • @TheRomanianWolf
    @TheRomanianWolf 7 місяців тому

    Very nice and straightforward explanation!

    • @kantancoding
      @kantancoding  6 місяців тому

      Thank you! Happy to help 🙂

  • @AlexXavier
    @AlexXavier 8 місяців тому

    Helpfull? Are you kiding? Was amazing!

    • @kantancoding
      @kantancoding  7 місяців тому +1

      I’m really happy to hear that. Thank you!

  • @peternydahl6150
    @peternydahl6150 6 місяців тому +1

    Thank you so much, that was indeed a perfect tutorial! Genius :)

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

    I wish I go hug you my friend. You channel is such a gem.

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

      *virtual hug. thank you! I'm happy to help bro

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

    My understanding about builder pattern is use a predefined object inside director class and get the product of our choice Imagine we have a house, different preference of house by different people, instead of constructing a house of one’s choice, why not create a different type of house that are possible and use director to get the house. This saves time as well as avoid bloating of constructors.

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

    Thanks a lot. Had a lot of trouble with this pattern

  • @chandrikasaha6301
    @chandrikasaha6301 Рік тому +2

    This was great! Want more design patterns in python please

    • @kantancoding
      @kantancoding  Рік тому +2

      Hey! Thanks for the feedback. I’ll likely add more to this playlist eventually. All depends on demand really.

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

      @@kantancoding not sure how youtube ranks videos. i guess by adding the language in the thumbnail would make your videos come on top once searched, because most of the design pattern videos are in java. Also you may add catchy captions, such as 'concept to code - so that you can code your way' etc. I just happened to have stumbled on this. now i keep searching if your new video has come on design patterns. Your videos on design pattern in python are the best which clarifies the fundament of the pattern definition and demonstrate the code with meaningful example. Honestly, this one was intuitively the best among all i have watched/read - and i had browsed a lot before coming here

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

      @@chandrikasaha6301 Yeah the reason I didn't put Python is because you don't need to know Python to understand this video. I'm pretty sure that as long as you know any programming language you will be able to understand this.. But I always forget how language specific people are when learning. I was the same way in the beginning actually so not sure why I always forget this. I think it's a good idea. Thank you

  • @ivanmenshchikov4288
    @ivanmenshchikov4288 Рік тому +4

    The explanation is very detailed. Thank you. However I would pay more attention to the use cases (when and why do we need this pattern). And I would also use a different language such as Java, C# or Typescript in order to make it easier to understand for people that are not familiar with python syntax. It's also easier to understand what are the instances of variables with those languages.

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

      Good points. I considered adding "when and why" to use the patterns but I felt the videos would be too long for the average attention span. The most recent video that I'm releasing later on goes into a bit more detail about when and why and it easily exceeds 20 minutes. Kind of need to play the balancing game.
      I think you make a really good point about the language and I actually almost used Java (I also considered Go) but I ended up going with Python because it's easy to read. But who knows, maybe I'll remake the videos for multiple languages. Not sure yet.

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

      @@kantancoding I think the language selection as Python is fine, and I'm really thankful for it.

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

      If you want this for a different language, then use the search bar to find it :)

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

    If I may ask, what software do you use for the whiteboard like representation of the video?

    • @kantancoding
      @kantancoding  Рік тому +2

      I use davinci resolve for pretty much everything 😉

  • @chandrikasaha6301
    @chandrikasaha6301 Рік тому +2

    If you could make one on Adapter pattern and Strategy pattern please. These confuse me a lot. Adapter - because i get confused with which needs to be wrapped - the examples around contribute more to the confusion. Strategy because it looks like a if-else which is more like a factory - though factory is a creational pattern and strategy a behavioral one

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

      same here

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

      Thanks for the feedback. I will consider it 😊

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

    The fact you only have 40k subs is a crime. Subscribe people

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

      Hey, thanks for the support 🙂
      More subs will come!

  • @fissoleouf23
    @fissoleouf23 3 місяці тому

    Hi ! Why the House class constructor takes the Builder in argument ? There is other ways to do that isnt't it ?

    • @kantancoding
      @kantancoding  3 місяці тому

      There are other ways to do everything my friend 😊

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

    Let's always do alot of good and encourage others to do the same

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

    very good explanation.. dude you are awesome!! Thanks

  • @imran-potter
    @imran-potter Рік тому +1

    Hey man, why u stopped making videos about algo patterns? please, do continue

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

      Which patterns are you looking for? I think I did all of the most common ones but I wouldn’t mind adding more

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

      @@kantancoding Please make one on Strategy, registry, decorator, flyweight using Python. This one logically made so much sense

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

    can we achieve immutability with this in python

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

      Hmm, probably better to narrow down your question? 🤔

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

      in your Director class, you could create a specification class variable, that would contain set specs for each house type as a tuple, for example :)

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

    helpful

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

    eXcellent’e

  • @alexander_sinclair
    @alexander_sinclair 8 місяців тому

    I don't understand the purpose

  • @industrialdonut7681
    @industrialdonut7681 Рік тому +3

    jesus christ this pattern is a dumpster fire

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

    This feels like such a waste of

  • @high-level-content-maker
    @high-level-content-maker 8 місяців тому +1

    why all similar explanations are explained by the example of dogs, houses and similar nonsense? Do the authors think that we, programmers, will not be able to perceive an example from a real design problem? imho, such explanations are suitable only for those who need to get an assessment at an educational institution

    • @kantancoding
      @kantancoding  8 місяців тому +1

      It’s just easier to explain in isolation instead of needing to explain some complex architecture as well as the design pattern.

    • @sebastianseelos6431
      @sebastianseelos6431 8 місяців тому

      The are actually programs dedicated to literally help building houses 🤨

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

      Not everyone works with the same technologies, not everyone is a webdev. But everyone knows what a house is. The assumption is not that you are dumb, the assumption is that you are smart enough to extrapolate the example to solve problems that you have.

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

    I really nice way to use this is for unit tests. If your class takes in like 15 params, you create a default builder for your happy path, and then can individually change individual fields to test your edge cases.
    happyPath = builder.build()
    InvalidZipCode = builder.setZipCode("INVALID_ZIP_CODE")
    IgnoreInvalidZipCode = builder.setZipCode("INVALID_ZIP_CODE").setIgnoreInvalidZipCode(true)

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

      Yes! We actually do this quite often when writing unit tests in Java. Good insight 🔥