Hey Christopher, when you mention you use the Decorator pattern when trying to deprecate the usage of some class, wouldn't an Adapter/Facade pattern be better for that? I'm new to design patterns so I'm just trying to analyze it a bit :) BTW, when is the next pattern coming out?
Excellent question! While filming, this question struck me as well. It's really quite hairy. They are deviously similar and I keep forgetting the nuances :) TLDR; I agree with you. But, let's define the concepts... 1) The adapter adapter pattern changes the interface but does not change the implementation. 2) The proxy pattern changes the implementation but does not change the interface. 3) The decorator pattern changes the implementation but does not change the interface. 4) The facade pattern is a high-level level abstraction over low-level components, where the interface is changed. So, I guess it boils down to proxy vs decorator. The deprecation example I gave could, depending on the scenario, probably be technically considered decorator pattern. But then again, it's a too simplistic example that doesn't really take advantage of the true power of decorator pattern. So I agree with your comment. Further, my example becomes even more silly if we look at it in a statically typed language (I usually work in dynamically typed languages and was thinking of that when I blurted out the example). In the decorator pattern we have the two interfaces Component and Decorator. The old class we want to deprecate is a Component, but if we were to use Decorator Pattern to deprecate it then the new concrete class would have to be a Decorator which in turn is a Component. From an abstraction point of view, this is actually a good thing because the abstract Decorator could then make sure to delegate all method calls to the decorated Component, which leaves the concrete Decorator with the job of only implementing the few methods it wants to change. But then again... this is probably massive overkill, and you'd be better off just throwing in a proxy where the proxied object is dependency injected into the proxy. Interesting excursion :) Thank you for the comment. I need to think my examples through a bit better before rocking it :) Ps. I've got an older video on Adapter vs Facade vs Proxy here: th-cam.com/video/hTC3rmRBIxs/w-d-xo.html
Thank you for a very detailed and educational answer :) I still haven't touched the Proxy pattern which I'll do next and that is probably the reason why Adapter and Facade were the first that came to mind. For now it makes sense why and how to use the Decorator for deprecation even if it is an overkill. It's good to have these examples in your videos because they give us the opportunity to think about them and ask when unclear, so keep it up, it's all good :) I enjoy the Code Walks as well, especially liked the one about VR/AR and moving coding away from the monitor+keyboard environment!
@2:38 Wow... I spent, like, 3 days a couple months ago researching Abstract classes and didn't manage to gain, like, a lick of insight. This guy sums it in a TOTALLY understandable way in all of a minute.. and this tutorial isn't even about abstract classes!!
This series is becoming one of my favorite coding tutorial series here on TH-cam, as a combination of the delivery and the value. Every video keeps me engaged from beginning to end, and each has all I need to start applying the concept to my own projects. Thanks for making them.
You asked us in the video if you should change anything. Please don't change anything. Your videos are goddamn awesome! Just keep making more videos. The community needs people like you who have the knack to explain things the way you do. Man, you are 100 times more valuable than all my university professors put together. World's best CS instructor!
It's funny because before watching your videos I was getting information about patterns on different sources, and it seemed to me that all different sources were saying different things on the same pattern. Then after watching your videos I realized that all these sources were saying the same thing. Definitely the simplest explanation ever. Thank you!
The best part of this video series that Christopher Okhravi is teaching from a book. At first these vidio series were not making any sense to me. But after I read the chapter from the book and came back to this video I understood the concept even better. Thanks Christopher for making videos on TH-cam. I wonder where have you gone since 6 years now !!!!
I do not have patience to watch long explanation. But I confess that I watched the first three videos in one seat with out getting bored. Congratulation for the excellent explanation!
by far, you are the best. your teaching and explaining methods are simple and easy ( and in the world of programming, that is priceless ) waiting for the next episode.
I don't usually comment on videos. But this time I have to. Because you completely nailed it man best explanation ever heard! Before I used to think that I understand DP. But after watching your video I relalised that I actually don't.
HOOOOlLLLLLYYYY CRAP, I was recommended your videos by the YT Algorithm and I was like, "nah, I'm just a Junior Dev, I ain't gonna need Design Patterns for another year"... WRONG! So glad the algorithm found you again. Subscribed.
When reading the book I kept on asking myself why we were calling the toppings (Soy, Mocha, Whip, etc) beverages and even using an "IS-A" relationship when they clearly aren't beverages lol. So those two key pieces of information at the end really helped me understand this pattern. 1. You should look for alternatives if the Decorators you are using aren't actually of the type of component which you are initially wrapping. 2. You shouldn't use Decorator Pattern when the only variation between Decorators is a couple of properties. I feel like watching your explanations really complements the information in the book and will continue to watch the rest of the series. Thanks for this!
I would also argue that for this Coffee example, the decorator pattern is an overkill. I think the suggested solution at 48:30 is a more suitable one. I just wanna say thank you a ton for your hard work. Please keep making more videos 👍.
Outstanding! Thank you so much for all of the quick cuts throughout the video. This shows great respect for your audience's time and makes the content much more interesting, digestible, and entertaining!
This is really good stuff. Please don't stop making these videos, unless you've already exhausted all the information of course. You're a really good teacher and you're easy to follow.
Around ~8:00, in Java, at least, when you made this video, you can indeed have default instance method behavior in an interface, of course, I know this is considering various languages with examples in Java, but that is something that could be mentioned. I don't think you are monitoring this channel very closely, but this series is just racking up more and more views. Very good stuff.
Awesome explanation (Special applause for telling how decorative pattern is more useful in cases of behavioural changes rather than value changes which is a better scenario for using iterator patter). If someone has not gone through iterator pattern, just by that line of yours he/she will get to know everything about the iterator pattern. Great Teacher you are. Keep on doing the good job of educating others.
For those who are looking for the difference of using a decorator and a List, go to 46:30, Christopher talked how the classical example of beverage, or pizza is unsuitable for the decorator pattern and scenarios that make it suitable.
I'm EXTREMELY happy that I recently found your channel. Been watching your design patterns playlist in order and I've been actually getting pretty excited about implementing them in my code! So far, I've found the talks about Observer and this one about decorators to be suuupperr helpful with a thread-safe logging library I'm making for use in other personal projects where the observer pattern is used in managing multiple loggers and progress indication bars and this decorator pattern is used in the logger sinks and progress bar attributes. Again, Thank You for making easy-to-digest videos as they have been super helpful in grasping new concepts so far!
This the the This video I have watched. This is amazing. Clear, concise, hits home on all the points to clarify the design and how it is implemented. I have not been able to get this clarify for years by reading books. Past 2 days of watching your videos was time well spent.
I've just started to dip my toes into design patterns and boy am I glad I found this video. Excellent explanation. Heard about the book but now I'm more motivated to start reading it. I'm sure it will go super well together with your videos. Thank you!
Thank you for taking the time on explaining the Decorator pattern. I've been introduced to it for the first time on this video and it is all thanks to you. I found this resource helpful and useful at the same time, you are very good in being able to illustrate all the different perspective to this subject.
Hey Christopher, thank you! your prodigious energy, and no-beating-the-bushes style of teaching is awesome. You convey your ideas very clearly, and succinctly
That was awesome! A detailed neat explanation ... Now I got how the linq operators work under the hood ! This pattern with method chaining in C# will be absolutely great. Thank you !
I absolutely love listening to you. Not only you explain everything in a great and understandable way but you also have such an awesome vibe going on. Love it.
Christopher, your explanations are among the best , multi level references, kept my mind focused and thanks of that i can simply remember more. Thank you.
Awesome job, as always! Just one teeny tiny point - in teaching, repetition is good. It's more than good - it's crucial. I can't stress enough how crucial it is. But keep in mind that repetition of a concept does not necessarily mean explaining it multiple times. Explain it thoroughly once or twice and then repeat, repeat, repeat but only the gist of the concept or even just the name of it. I'm talking about the HAS-A/IS-A part in your video - it's sufficient to explain it once or twice and then to remind your audience: "remember: IS-A/HAS-A" so they immediately think about "decorator pattern" when they hear "IS-A/HAS-A" or vice versa. Just a quick tip from a methodological point of view, I hope you don't mind my babbling. Anyway thanks for the video, can't wait to see more!
Very very very good explanation. I'm impressed. It is obvious that you're getting better with every video. Video is a little bit long, but you've managed to keep my attention. Great job. Regards from Serbia.
Nice video. I am teaching programming and your whiteboard + cut seems to be the key. The pace is perfect. Usually i finish the class with a nice board picture provided in a confuse way or i just need to long to draw and write the illustrations.
4:21 Discussing the definition of decorator pattern 19:02 How to apply the decorator pattern to the example. 31:47 Generalized UML diagram. 46:31 Why I think this example is not suitable for the decorator pattern. 52:40 Last thing about the example: how to use it.
After listening to 1 hour of how not to implement the coffee shop system I was really wondering what would be the most efficient way instead? Anyway, this video really cleared my mind regarding the decorator pattern, so mission accomplished!
I absolutely love these explanations. Thanks so much for them. I found it confusing to think of Caramel/Chocolate as types of beverages. It helped me to think of the Abstract Beverage class as a 'Product' instead. Both Espresso and Caramel are Products that the coffee shop sells, but Espresso is the base Product. Caramel is an addon but also still a Product.
Christopher, thank you so much. I finally came across your channel today when searching for info on the decorator design pattern(liked and subscribed). It is exactly what I have been looking for. I go to school online and sadly there is little to no actual "face-to-face" instruction. By that I mean, we have assignments, and are essentially left to own to figure out how to work through them. In fact the class I am taking now does not even have an accompanying textbook. I don't learn well by relying on slow email correspondence ( I am a busy man) to drive some complex principles home. Sometimes I need to have things broken down into very simple terms and viewed from several different angles to finally sink in, so that I can actually use it in practice and not just theory. Your approach here is exactly what the Dr ordered. Again, thank you very much.
Hi Christopher, thank you very much for this informative video! I was quite frustrated with the material that my teacher handed out, because I didn't understand what exactly the pattern is and how it's used, but now I do :)
Your way of repeating things over and over again is absolutely brilliant, keep doing this. Well done. I thank you. Also, the very last part where you showed how to actually implement it - that is very important as well! I was wondering if that would show up at it thankfully did. Absolutely wonderful job all around.
my third video of the day. its very engaging. I just wish you have the same pattern for all. Meaning as always you start with the definition , then problem and the possible solution using the pattern. Overall it was really very educational. Thanks heaps for your efforts.
Hi Christopher, I by mistake came across your channel and am wonderstruck with your style of telling the things. I already had the book but everything never meant much sense until I started watching your videos.Thanks for making things simple. Eagerly waiting for your next videos. Please keep us posted. :)
You are doing an amazing job! Great content, well explained. You seem to master these topics but you stay very humble and you ask people their opinion about your explanation and implementation/illustration. Plus I like your ability to talk so fast and stay understandable at the same time. That's mind-blowing
hey Christopher, great explanation. You have unique way for explain complicated things to be easy understand, thank you very much ! I am looking forward for the next chapters...
:D 52:14 Wild cat appears! Your vids are great, I'm watching them after read the chapters of the book, it's a good book but thanks to you the concepts are retained and assimilated better, while reading the Beverage example I was thinking too maybe it was not the best way of coding that program, now you have made clear the reason 8) thanks xD besides it keeps me awake when you cut your movements in the vid lol it would be funny if teachers could do this in class
+10 bonus points for noticing the wild cat! :) :) Thanks for your comments. And indeed it's quite a benefit to be able to cut your presentation. Much harder for teachers in class, agreed :) :)
Fantastic! - always saving out time by editing the video - mention a lot of importent things (even those that not always related) - your emotions that helps to understand and remember much better Thank you so much for creating such useful videos.
Hi me again. Just read the comment below and just realised my idea though it works is not an implementation of the Decorator Pattern as you have described. I think that probably proves just how good your teaching method is. Thanks.
Great work, Christopher! I am really enjoying the series! Just a slide comment... when you are introducing the abstract class AddonDecorator, I find it appropriate to add a constructor "public AddonDecorator(Bevarage bevarage)", so, on one hand, you are explicit that a "Decorator has a Component", and on the other hand, that would obligate all "ConcreteDecorator"-s having such constructor. Once again thank you for the videos!
Even the cat is interested in your explanation. Great work! Please keep doing this. I'm reading the book too, and this is making my learning really keep in my mind. Thank you a lot ^_^
Your presentations are so good, that there will be no more interview questions related to these patterns, since everyone knows them if watched your vids:)
A huge respect and admiration to you for sharing your knowledge in such a lucid way. I would request if you can also include some real life use cases at end of each pattern, it would help us tremendously.
Hey Christopher, when you mention you use the Decorator pattern when trying to deprecate the usage of some class, wouldn't an Adapter/Facade pattern be better for that? I'm new to design patterns so I'm just trying to analyze it a bit :) BTW, when is the next pattern coming out?
Excellent question! While filming, this question struck me as well. It's really quite hairy. They are deviously similar and I keep forgetting the nuances :) TLDR; I agree with you. But, let's define the concepts...
1) The adapter adapter pattern changes the interface but does not change the implementation.
2) The proxy pattern changes the implementation but does not change the interface.
3) The decorator pattern changes the implementation but does not change the interface.
4) The facade pattern is a high-level level abstraction over low-level components, where the interface is changed.
So, I guess it boils down to proxy vs decorator.
The deprecation example I gave could, depending on the scenario, probably be technically considered decorator pattern. But then again, it's a too simplistic example that doesn't really take advantage of the true power of decorator pattern. So I agree with your comment.
Further, my example becomes even more silly if we look at it in a statically typed language (I usually work in dynamically typed languages and was thinking of that when I blurted out the example). In the decorator pattern we have the two interfaces Component and Decorator. The old class we want to deprecate is a Component, but if we were to use Decorator Pattern to deprecate it then the new concrete class would have to be a Decorator which in turn is a Component. From an abstraction point of view, this is actually a good thing because the abstract Decorator could then make sure to delegate all method calls to the decorated Component, which leaves the concrete Decorator with the job of only implementing the few methods it wants to change. But then again... this is probably massive overkill, and you'd be better off just throwing in a proxy where the proxied object is dependency injected into the proxy.
Interesting excursion :) Thank you for the comment. I need to think my examples through a bit better before rocking it :)
Ps. I've got an older video on Adapter vs Facade vs Proxy here: th-cam.com/video/hTC3rmRBIxs/w-d-xo.html
Thank you for a very detailed and educational answer :)
I still haven't touched the Proxy pattern which I'll do next and that is probably the reason why Adapter and Facade were the first that came to mind. For now it makes sense why and how to use the Decorator for deprecation even if it is an overkill.
It's good to have these examples in your videos because they give us the opportunity to think about them and ask when unclear, so keep it up, it's all good :)
I enjoy the Code Walks as well, especially liked the one about VR/AR and moving coding away from the monitor+keyboard environment!
Christopher Okhravi, Thank you very much for these amazing videos.
In this case , i think proxy pattern makes sense. Awesome video Chris .
BEST saxo ever
I love how the cat wanted to learn about the Decorator pattern at the end. Love the videos by the way
@2:38 Wow... I spent, like, 3 days a couple months ago researching Abstract classes and didn't manage to gain, like, a lick of insight. This guy sums it in a TOTALLY understandable way in all of a minute.. and this tutorial isn't even about abstract classes!!
This man's explanation is so much better than any prof I have in uni and all other TH-camrs. Thank you.
This series is becoming one of my favorite coding tutorial series here on TH-cam, as a combination of the delivery and the value. Every video keeps me engaged from beginning to end, and each has all I need to start applying the concept to my own projects. Thanks for making them.
noob
One of the best explanation in TH-cam pattern videos, classic!
One of the best comments on TH-cam :) :) ;)
execuse me this is the best not one of the best. believe me i went trought them all.
@@ChristopherOkhravi (One of the best comm......) 😁 yes, it is true.
Not one of the best. But actually THE BEST OF EM ALL
You asked us in the video if you should change anything. Please don't change anything. Your videos are goddamn awesome! Just keep making more videos. The community needs people like you who have the knack to explain things the way you do. Man, you are 100 times more valuable than all my university professors put together. World's best CS instructor!
It's funny because before watching your videos I was getting information about patterns on different sources, and it seemed to me that all different sources were saying different things on the same pattern. Then after watching your videos I realized that all these sources were saying the same thing. Definitely the simplest explanation ever. Thank you!
More than TH-cam supporting you, its actually you are helping youtube to provide such a quality content to public. Thanks for sharing this.
The best part of this video series that Christopher Okhravi is teaching from a book. At first these vidio series were not making any sense to me. But after I read the chapter from the book and came back to this video I understood the concept even better. Thanks Christopher for making videos on TH-cam. I wonder where have you gone since 6 years now !!!!
the way you are teaching is genius, I watch one video and get it all, no need to look anything up afterwards
I cleared three interviews back to back ... coz of this man... keep it up...
I've never heard a better explanation of the decorator design pattern. Thank you.
I do not have patience to watch long explanation. But I confess that I watched the first three videos in one seat with out getting bored. Congratulation for the excellent explanation!
by far, you are the best.
your teaching and explaining methods are simple and easy ( and in the world of programming, that is priceless )
waiting for the next episode.
Osama Tamimi Thanks for taking the time to write this comment. I appreciate it. I'm glad the video is useful :)
I don't usually comment on videos. But this time I have to. Because you completely nailed it man best explanation ever heard!
Before I used to think that I understand DP. But after watching your video I relalised that I actually don't.
HOOOOlLLLLLYYYY CRAP, I was recommended your videos by the YT Algorithm and I was like, "nah, I'm just a Junior Dev, I ain't gonna need Design Patterns for another year"...
WRONG!
So glad the algorithm found you again.
Subscribed.
When reading the book I kept on asking myself why we were calling the toppings (Soy, Mocha, Whip, etc) beverages and even using an "IS-A" relationship when they clearly aren't beverages lol. So those two key pieces of information at the end really helped me understand this pattern.
1. You should look for alternatives if the Decorators you are using aren't actually of the type of component which you are initially wrapping.
2. You shouldn't use Decorator Pattern when the only variation between Decorators is a couple of properties.
I feel like watching your explanations really complements the information in the book and will continue to watch the rest of the series. Thanks for this!
I would also argue that for this Coffee example, the decorator pattern is an overkill. I think the suggested solution at 48:30 is a more suitable one.
I just wanna say thank you a ton for your hard work. Please keep making more videos 👍.
Outstanding! Thank you so much for all of the quick cuts throughout the video. This shows great respect for your audience's time and makes the content much more interesting, digestible, and entertaining!
Came here after reading and leaving Head First's Decorator chapter confused. This video makes everything super clear! Thank you.
This is really good stuff. Please don't stop making these videos, unless you've already exhausted all the information of course. You're a really good teacher and you're easy to follow.
Around ~8:00, in Java, at least, when you made this video, you can indeed have default instance method behavior in an interface, of course, I know this is considering various languages with examples in Java, but that is something that could be mentioned.
I don't think you are monitoring this channel very closely, but this series is just racking up more and more views. Very good stuff.
You are a savior. Thanks for your time and care about community 💐
Awesome explanation (Special applause for telling how decorative pattern is more useful in cases of behavioural changes rather than value changes which is a better scenario for using iterator patter). If someone has not gone through iterator pattern, just by that line of yours he/she will get to know everything about the iterator pattern.
Great Teacher you are. Keep on doing the good job of educating others.
For those who are looking for the difference of using a decorator and a List, go to 46:30, Christopher talked how the classical example of beverage, or pizza is unsuitable for the decorator pattern and scenarios that make it suitable.
Love how "coffee" starts to lose its meaning and becomes just a data thing during this video 😂
just kidding. Love your content, the best I found in yt
mid-way through the video, but had to tell you you're teaching is top-notch!
I'm EXTREMELY happy that I recently found your channel. Been watching your design patterns playlist in order and I've been actually getting pretty excited about implementing them in my code! So far, I've found the talks about Observer and this one about decorators to be suuupperr helpful with a thread-safe logging library I'm making for use in other personal projects where the observer pattern is used in managing multiple loggers and progress indication bars and this decorator pattern is used in the logger sinks and progress bar attributes. Again, Thank You for making easy-to-digest videos as they have been super helpful in grasping new concepts so far!
This the the This video I have watched. This is amazing. Clear, concise, hits home on all the points to clarify the design and how it is implemented. I have not been able to get this clarify for years by reading books. Past 2 days of watching your videos was time well spent.
You really feel and understand very clear what you are saying about. Good job Chris! Great explanation!
Wow.. I didn't sleep in a long lecture? what a miracle!
just watched this and my mind is blown u explained it so well its so simple
51 min to explain decorator, I never seen so long explanation of a pattern. That's excellent
I've just started to dip my toes into design patterns and boy am I glad I found this video. Excellent explanation. Heard about the book but now I'm more motivated to start reading it. I'm sure it will go super well together with your videos. Thank you!
What a cool tutorial. thanks for a comprehensive tutorial and charisma. 50 mins passed so fast!
Thank you for taking the time on explaining the Decorator pattern. I've been introduced to it for the first time on this video and it is all thanks to you. I found this resource helpful and useful at the same time, you are very good in being able to illustrate all the different perspective to this subject.
Hey Christopher, thank you! your prodigious energy, and no-beating-the-bushes style of teaching is awesome. You convey your ideas very clearly, and succinctly
Best explanation about Decorator. after 5 videos, it finally makes sense.
That was awesome!
A detailed neat explanation ... Now I got how the linq operators work under the hood !
This pattern with method chaining in C# will be absolutely great.
Thank you !
I love your method of teaching. Ez than reading than the books.
I love your teaching pattern. And I want to learn all these patterns from this playlist.
I absolutely love listening to you. Not only you explain everything in a great and understandable way but you also have such an awesome vibe going on. Love it.
One of the best explanations I've ever seen.
You are a great teacher
Thank you for so nice work you are doing! Was a honor to view your teaching. Very useful.
Christopher, your explanations are among the best , multi level references, kept my mind focused and thanks of that i can simply remember more.
Thank you.
The best video about decorator pattern I have ever seen!
Awesome job, as always! Just one teeny tiny point - in teaching, repetition is good. It's more than good - it's crucial. I can't stress enough how crucial it is. But keep in mind that repetition of a concept does not necessarily mean explaining it multiple times. Explain it thoroughly once or twice and then repeat, repeat, repeat but only the gist of the concept or even just the name of it. I'm talking about the HAS-A/IS-A part in your video - it's sufficient to explain it once or twice and then to remind your audience: "remember: IS-A/HAS-A" so they immediately think about "decorator pattern" when they hear "IS-A/HAS-A" or vice versa. Just a quick tip from a methodological point of view, I hope you don't mind my babbling. Anyway thanks for the video, can't wait to see more!
Very very very good explanation. I'm impressed. It is obvious that you're getting better with every video. Video is a little bit long, but you've managed to keep my attention. Great job. Regards from Serbia.
Awesome! After several tries now I understand it better here, the decorator pattern. Thanks.
Nice video. I am teaching programming and your whiteboard + cut seems to be the key. The pace is perfect. Usually i finish the class with a nice board picture provided in a confuse way or i just need to long to draw and write the illustrations.
4:21 Discussing the definition of decorator pattern
19:02 How to apply the decorator pattern to the example.
31:47 Generalized UML diagram.
46:31 Why I think this example is not suitable for the decorator pattern.
52:40 Last thing about the example: how to use it.
After listening to 1 hour of how not to implement the coffee shop system I was really wondering what would be the most efficient way instead? Anyway, this video really cleared my mind regarding the decorator pattern, so mission accomplished!
Still the best video ever about explaining the decorator pattern.
I would recommend this channel to all my collages who wants to learn about design patterns. You are doing an amazing job Christopher. Thanks a lot. :D
I absolutely love these explanations. Thanks so much for them.
I found it confusing to think of Caramel/Chocolate as types of beverages. It helped me to think of the Abstract Beverage class as a 'Product' instead. Both Espresso and Caramel are Products that the coffee shop sells, but Espresso is the base Product. Caramel is an addon but also still a Product.
dude, your explanation is extraordinary, hatsoff for your effort to make us understand. Thank you bro for making these videos on design patterns
i like the explanation. programmers who are doing Point of sale System can totally understand your explaination.
Christopher, thank you so much. I finally came across your channel today when searching for info on the decorator design pattern(liked and subscribed). It is exactly what I have been looking for. I go to school online and sadly there is little to no actual "face-to-face" instruction. By that I mean, we have assignments, and are essentially left to own to figure out how to work through them. In fact the class I am taking now does not even have an accompanying textbook. I don't learn well by relying on slow email correspondence ( I am a busy man) to drive some complex principles home. Sometimes I need to have things broken down into very simple terms and viewed from several different angles to finally sink in, so that I can actually use it in practice and not just theory. Your approach here is exactly what the Dr ordered. Again, thank you very much.
Never heard better explanation than this about design patterns.. you are awesome..
Greatly explained!
Totally agreed w/ your comments towards the end
Thank you so much for explaining in such detail. Respect from India! :)
Hi Christopher, thank you very much for this informative video! I was quite frustrated with the material that my teacher handed out, because I didn't understand what exactly the pattern is and how it's used, but now I do :)
I don't feel of time when watching this series ... Great explanation
OMG, this is the very best abstract explanation ever....
Your way of repeating things over and over again is absolutely brilliant, keep doing this. Well done. I thank you. Also, the very last part where you showed how to actually implement it - that is very important as well! I was wondering if that would show up at it thankfully did. Absolutely wonderful job all around.
Hands down the best explanation you'll ever find on the Internet! Thank You
Best explanation I've heard of the pattern, Christopher, you might have taken a break from TH-cam but you have a gift for teaching!
best explanation on youtube by far
Thank you for talking about why we might use an abstract class instead of an interface. That was a helpful aside. (at 7:53)
my third video of the day. its very engaging. I just wish you have the same pattern for all. Meaning as always you start with the definition , then problem and the possible solution using the pattern. Overall it was really very educational. Thanks heaps for your efforts.
Great description! Read that book about 10 years ago but never understood the pattern as much as I do now having seen your video.
That's awesome! I'm glad to hear the videos complement the contents of the book. Thank you very much for sharing and for watching :)
Hi Christopher, I by mistake came across your channel and am wonderstruck with your style of telling the things. I already had the book but everything never meant much sense until I started watching your videos.Thanks for making things simple. Eagerly waiting for your next videos. Please keep us posted. :)
Thank you for the kind words :) :)
This channel is exactly what I needed. Thank you for existing. You are doing a golden job!
The way you edit the videos keeps us concentrated. Like a Guy Ritchie movie :)
Dude you're amazing. Thanks man really helped me with my CS course
You are doing an amazing job!
Great content, well explained. You seem to master these topics but you stay very humble and you ask people their opinion about your explanation and implementation/illustration.
Plus I like your ability to talk so fast and stay understandable at the same time. That's mind-blowing
The way you explain the material is awesome!
hey Christopher, great explanation. You have unique way for explain complicated things to be easy understand, thank you very much ! I am looking forward for the next chapters...
Thank you for the kind words. And thanks for watching.
A clever way of using recursion and polymorphism, great explaination!
:D 52:14 Wild cat appears! Your vids are great, I'm watching them after read the chapters of the book, it's a good book but thanks to you the concepts are retained and assimilated better, while reading the Beverage example I was thinking too maybe it was not the best way of coding that program, now you have made clear the reason 8) thanks
xD besides it keeps me awake when you cut your movements in the vid lol it would be funny if teachers could do this in class
+10 bonus points for noticing the wild cat! :) :) Thanks for your comments. And indeed it's quite a benefit to be able to cut your presentation. Much harder for teachers in class, agreed :) :)
Hey, how are you? i like your funny things and funny face you make at the beginning of your videos. And you are good teacher.
Nikte Aeon i
Fantastic!
- always saving out time by editing the video
- mention a lot of importent things (even those that not always related)
- your emotions that helps to understand and remember much better
Thank you so much for creating such useful videos.
Dude i wish you will live forever to teach everyone in this world 😁
It's first time to see you or know about you , but after only 5 minutes watching I feel that I need and should watch all your videos :)
+Mohamed Abou-Emish Awesome :) Feel absolutely free to do :) :) Thank you for the comment.
On my 5th video with this dude. He is amazing. Dude needs to get back to it.
Really awesome playlist, I can easily understand the patterns even though I’m not a native speaker.
Hi me again. Just read the comment below and just realised my idea though it works is not an implementation of the Decorator Pattern as you have described. I think that probably proves just how good your teaching method is. Thanks.
I can't seem to find the context of this question so I'm not entirely sure what you mean :) But, I thank you :)
Ah, I see now that you probably meant that you deleted it? Thanks anyway! :)
Great work, Christopher! I am really enjoying the series! Just a slide comment... when you are introducing the abstract class AddonDecorator, I find it appropriate to add a constructor "public AddonDecorator(Bevarage bevarage)", so, on one hand, you are explicit that a "Decorator has a Component", and on the other hand, that would obligate all "ConcreteDecorator"-s having such constructor. Once again thank you for the videos!
Hi, I just wanted to say that you explain this material very well. Thank you!!
Great video, please do not stop making these!
92MarckO Thanks! No worries. I won't.
Waiting for next videos..... please......
Even the cat is interested in your explanation. Great work! Please keep doing this. I'm reading the book too, and this is making my learning really keep in my mind. Thank you a lot ^_^
Thank you for the amazing explanation, I finally understood the decorator pattern
Your presentations are so good, that there will be no more interview questions related to these patterns, since everyone knows them if watched your vids:)
You know the person is good teacher when you understand what they convey even at a 2x speed .. :'D
I never seen any better explanations of anything! Thanks a lot!
This guy actually explains the work in an understandable manner, if he was my professor, then maybe the other half of students would still be there.
noob
@Christopher Okhravi You are good teacher. Thank you.
And here I thought I would never get Design Patterns! you are AWESOME!
This man's explanation is so much better than any prof I have in uni and all other TH-camrs. Thank you.
A huge respect and admiration to you for sharing your knowledge in such a lucid way. I would request if you can also include some real life use cases at end of each pattern, it would help us tremendously.