Superb lecture. I saw 2-3 other youtube channels for understanding builder patterns. Many tried but were not clear due to bad examples, difficult code walkthrough. What separated this video from Yogita is that she explained the painful areas of non-builder pattern based examples, she explained a technical jargon of constructor telescoping, the examples made great sense, two example codes to make the understanding crystal clear. @Yogita Thank you so much
@PiyushPragyan2 жыл бұрын
Loved the design pattern series. I understood this in a single go. 😊
@sumitguptasg1 Жыл бұрын
I saw a couple of videos for builder patterns but this is really crisp and useful. Great, keep 'em coming.
@shubhamrajput3710 ай бұрын
This is the best explanation I have ever went across for Builder Pattern. Thanks a lot for your work, really grateful to you !!
@letsdosomething333311 ай бұрын
Mam your way of teaching is just so amazing..it gives an extra view to see the code and to understand the code in easiest way.grateful that i found you
@AshutoshSingh-mh7qm6 ай бұрын
what a nice value addition to my engineering life. I am enjoying watching the design pattern playlist. It's above par comparing to any paid courses. Thanks a lot ....
@number1inworld2 ай бұрын
The way u organize the course is nice. This is a simple design pattern which lacks the concept of OC principle.
@sekharsamanta62668 ай бұрын
Best ever video I've seen so far on design pattern
@jokhakararpan312 жыл бұрын
Hey Yogita, You have explained this in very simple way, with practical example. Really liked your work.
@aviator97282 жыл бұрын
Best series on design patterns please complete rest as well
@letsrock73542 жыл бұрын
In office I was writing code this way all along...just by following/understanding already written code... Never knew I was utlising Builder pattern
@rein2923310 ай бұрын
Finally in forever i understood this concept!!
@hbhatia9992 жыл бұрын
Refactoring has become very easy in this pattern with some cons to use according to usecase. Thanks for video.
@narenshalivahana1111 Жыл бұрын
superb example and explanation, understood in few minutes
@aakansha58892 жыл бұрын
One of the best explanation on builder design pattern!!
@AditiAgarwal16952 жыл бұрын
Such a crisp and easy-to-follow video. Thanks for making this... :)
@sumantkumar28872 жыл бұрын
Very simple and easy to understand , thank you for the design patterns series.😊
@ankushvashisht1158 Жыл бұрын
Wow!! You are such a good teacher.
@blitzc81469 ай бұрын
Beautifully explained! Subbed, Thank you!
@prabhagaikwad48492 жыл бұрын
Loving whatever content you are creating. Most easiest ways you try. Much appreciated. Thank you so much _/\_ _/\_
@democratcobra2 жыл бұрын
Thanks for the upload ..Great....Please Complete all Design Patterns.. 🙂🙂
@shriharikulkarni072 жыл бұрын
Thanks for the wonderful and easy explanation
@zeeshanalam4914 Жыл бұрын
Clear and precise!
@annabelleellis8098 Жыл бұрын
Awesome Explanation!! Great example use.
@mireazma Жыл бұрын
It's worth mentioning that C++ and C# (at least) simplifies all the charade to nothing by use of optional parameters.
@sakshamjain16 Жыл бұрын
It does. But builder pattern is worth to use when each component creation is complex.
@RahulVerma-fz2jf2 жыл бұрын
Hey Yogita. Huge fan of your video, crisp and easy to understand. For this (builder pattern) implementation, saw some other sites as well, seems like 1. using inner nested class is not the only to implement it. People are using combination of (interface and abstract classes to achieve the same). 2. In your implementation isn't the code duplicated, as in the UrlBuilder and Builder class, you are writing the same fields again. Looks a bit messy. Dont you think?
@manishdadheech8440 Жыл бұрын
Thanks for such a nice explanation. I have a doubt. Why are we using a static inner class in the builder design pattern? Can't we use a normal inner class? or can we do it without inner class?
@aaf2011 Жыл бұрын
Thank you for your efforts to deliver such great explanation and helping us understanding the weird parts about design patters however, I do have a question mark about using nested class why we had to use nested class instead of using sole abstraction builder class or interfaces?
@davidstigant4576 ай бұрын
I have the same question.
@shreysoni20542 жыл бұрын
This is really a very good video, thank you mam for creating such good videos.
@tenshin1119 ай бұрын
This is a good introduction into the Builder pattern but it misses a few things. How about making sure that required fields are actually enforced in the code? Right now nothing is stopping you from building the URL that contains only 'path' and 'query' parameters but is missing the protocol/hostname part.
@gauravsalunke86522 жыл бұрын
Thanks for easy explanation
@SoumikGhosh-ef1jn5 ай бұрын
It would be very helpful if we could get the code for the same as it helps in grasping the concept even better.
@ISHANICUTIEPIE2 жыл бұрын
Superb Explanation..
@PkSam07 Жыл бұрын
What if we try to make it un-immutable. I removed final from fields and then created getter and setters as well to make it un-immutable. I don't see any issue. If any?
@prakashbabugnanam79492 жыл бұрын
Very eazy to understand and simple & clean example. Loved it!!
@RohitChauhaniitr Жыл бұрын
One correction: builder.build() call should actually return the URL object instead of the builder object. This builder object is part of the URL object constructor such that the value set in the builder could be used to construct the URL object. Am I missing something ?
@PkSam07 Жыл бұрын
@francescovanspronsenyes, u can even rename the class UrlBuilder to just Url. In that case u ll get what u r looking.
@lakshaythegupta2 ай бұрын
Doesn't the objects still have other optional fields with value null? Its just like using a constructor with all params . Does it just helps to remove the extra nulls ,that we need to pass to the constructor, with all the params?
@noturhomie4973Ай бұрын
I have a question. Here we create two classes: URLBuilder and Builder and after coding the logic we called the constructor for URLBuilder and passed the Builder class object as a param. Why dont we make 1 class called URLBuilder and implement the same logic for each part of the url and for every part return the same object whose attributes we set(like we did in builder). We are going to create an object for the URLBuilder and for builder might as well create one class and from it create multiple instances or urls here. Is it cuz of abstraction or providing some depth as in layers to code or what?
@mdnadeemasgar6279 Жыл бұрын
Hi Yogita, can you please upload the code online and share the code url in the description. So that we can also try manipulating the code for the given design pattern.
@mickys49995 ай бұрын
I didnt understand one thing in builder pattern. What if we need to add another attribute to the static builder class like price? Do we need to modify the static class? How will we implement it?
@ThePakChina2 жыл бұрын
[1,2,3,4,5].map(d=>d*2).filter(d=>d
@ThePakChina2 жыл бұрын
Very good. Keep it up.
@sudocode2 жыл бұрын
Thanks a lot
@prashantchamoli7263 Жыл бұрын
Thanks! I just have one question. Why use inner static class here? Why can't we have those constructors directly in URLBuilder instead and chain individual constructors that return type URLBuilder?
@PkSam07 Жыл бұрын
Yes, I too tried so and it worked. Just fields and then field method which return object itself. Moreover, I removed final from fields and then created getter and setters as well to make it un-immutable. I don't see any issue? You found any ans?
@SankalpCollege-f2o11 ай бұрын
Great Video
@yaad1222 жыл бұрын
Thanks allot, I am learning a lot.
@sandeepnayak588825 күн бұрын
how can you create an instance of the inner static class Builder ?
@nitinkhulbe6234 Жыл бұрын
nicely explained
@Adarshpartha2 жыл бұрын
Thank you for providing such good videos. I have a question how is builder pattern advantageous than just having default constructor without parameters and calling setter function to initialise attributes.
@aakansha58892 жыл бұрын
Firstly we want do not want to use the new keyword(which Factory pattern solves) and second we use builder pattern to make objects immutable.
@abhishekrathour3137 Жыл бұрын
Hi, why can't we use default constructor along with setters to set the value of field instead of making constructor for every param
@TusharBorawake2 жыл бұрын
You have created object of static class Builder, which seems strange here... Same thing when I am trying to implement in typescript I am getting "Error"
@soumalyasahoo51842 жыл бұрын
But at last after using builder design , the URL class is of no use? what i mean to say is , we should be able to print url.protocol , instead of urlBuilder.protocol.
@sagarveКүн бұрын
Exactly, this is seriously misleading. I'm really surprised to see how this could've helped so many of these people commenting here.
@mireazma Жыл бұрын
7:41 People probably wonder why create a new object based on an existing static object instead of only using one? In other words: Why going through the hassle of a static Builder, private constructor and _new_ in URLBuilder.build() instead of just populating the _new_ in Demo.main()? The answer is immutability. And although it's not needed in this particular example, it's a clever example to follow in other situations.
@tharunadhits69578 ай бұрын
Because we need to use encapsulation to hide complexity of the code and for isolation
@ashish2610962 жыл бұрын
First of all thanks a lot for this series, learning a lot from it. I have one doubt, in build method we are hardcoding URLBuilder class. Can we somehow use factory pattern along with builder pattern to create the URLBuilder object? so that in future, if I need to create TinyURLBuilder or any other object I can do it with minimal changes
@joseph2073 Жыл бұрын
Yes, u can implement multiple patterns together
@rahulsrivastava1040 Жыл бұрын
Loved it
@himankgupta79682 жыл бұрын
Hi, wanted to know why can't we use default params in constructor as null to resolve unwanted fields in class in this case?
@sudocode2 жыл бұрын
We can it makes the code cumbersome and lengthy for no reason.
@santosh_bhat2 жыл бұрын
Imagine you have 10+ params and you just need to create objects with 2-3 values set. You will have to write null in all unwanted params place. (extra work) Imagine you need to create multiple similar objects. (unwanted code, extra work) Builder pattern to the rescue
@arpitkansal3785 Жыл бұрын
You did not explain why we can't use setters only? Yes, the code looks redundant but I would have liked some explanation over it. Moreover, @Builder annotations for classes allows its objects to be modified.
@PkSam07 Жыл бұрын
Yes I used setters and getters and then removed the final as well to make it un-immutable and it does work. I didn't get what's the problem in doing so? If anyone please let me know?
@narindermalik7008 Жыл бұрын
If there's no need of immutable object, then there are alternatives to builder. But immutability is a good thing specially in a threaded env.
@sathviksathish424311 ай бұрын
Easy peasy
@nathamuni9435 Жыл бұрын
PLZZZ SHARE THIS PROJECT GIT LINK
@atirrasheedhashmi2 жыл бұрын
Yeh transition bahut bakwas hai
@sudocode2 жыл бұрын
I hope you find peace of mind and freedom from whatever is bothering you in life.