Guys, can anyone tell the difference between Strategy and Bridge? They seem so similar. Basically allow a class to define an implementation on runtime. Strategy is about encapsulating and plugging-in a behavior... But isn't Bridge doing the same here? The ConcreteImplementors are basically the strategies. What's the difference?
So glad to hear that you're expanding this series from its original scope. This is an excellent series, actually useful as a learning resource. Thanks a lot for your time dude, and really good job so far. :)
I've be developing software for 23 years and, have read both books, and know and have used all of these patterns. I came looking for good tutorials for my less experienced team members, and even with knowing this information already, I can't stop watching these, they are excellent resources.
00:03 The bridge pattern is a part of the additional patterns mentioned in the book Design Patterns. 01:48 The bridge pattern decouples an abstraction from its implementation. 06:10 The Bridge Pattern decouples abstraction from implementation. 08:30 The Cartesian product is a new set of all combinations of two sets. 13:01 Different views and media types need to be handled in a flexible manner. 15:13 The bridge pattern allows combining any arbitrary resource with any arbitrary view. 19:14 Using the Bridge pattern reduces the number of classes needed to handle different combinations. 21:23 The bridge pattern allows us to isolate the specifications of artist resources and view nests. 25:43 The Bridge Pattern allows views to use specific methods from resources without breaking the interface segregation principle. 27:52 Avoid duplicating behavior across different resources. 31:38 The resources in the bridge pattern have different concretions. 33:31 A view in the Bridge pattern can access a resource that behaves as a resource. 37:17 Separating artist specific, book specific, and playlist specific functionalities into their own inheritance hierarchy. 39:14 The video discusses the Bridge Pattern in design patterns. 42:54 An artist resource implemented the interface IResource and adapted over an artist. 44:46 The artist resource needs to delegate to a specific artist to get the required information. 48:37 The Bridge pattern allows for separating platform-specific and platform-independent code. 50:34 The bridge pattern allows a view to ask a resource for the information it needs to construct a particular view.
Bridge pattern is used in creating custom item recyclerview in android. Custom item recyclerview means that the recyclerview can contain different items like tiles, buttons, text. When I first saw the custom recyclerview implementation in an actual codebase, it took me a lot of time to understand how it was working, but when I did, I was able to appreciate its beauty. I have only just now realized that it was bridge pattern used in custom recyclerview and things are more clear. Huge thanks Chris for compiling such an amazing playlist. Your way of teaching is commendable.
I will probably never thank you enough for these videos...! You explain things so clearly, I can spend days understanding a pattern then I watch your video and it just clicks and suddenly it's all clear. Thank you!!
The real thing about your explanations is that it's ok to be shortly distracted watching your video without loosing my train of thought. It's not necessary to be being in the full attention during whole video as in the case of classic university lectures. It's super helpful and the best thing for me.
Hahaha I have actually heard the Bean comparison before so I guess it must be true :) :) :) Anyways, thank you for the kind words and for watching the series :)
I learned from lot's of tutor all they do their best , but you are the best teacher, ...in starting I hate designed patterns because I didn't understood but after learning from I am fall In love with design pattern 😍💕
The best ever explanations of design patterns! You are awesome man! Please just don't stop recording new episodes. And your "code walk" series is really about those things that every programmer should think about. Do as many as possible, please :)
I cant express how great you have explained this. 10 min into the video and I already understand it better than by any videos or tutorials I watched or read before. Thanks!
Last time I watched your videos about 5-6 years ago and till now I watched a lot of other videos related to software engineering, but never saw someone explaining not like you, but even close to you.
Thats another great video. I love your explanations. Basically i would differentiate Bridge Pattern from Adapter pattern as the following: Adapter pattern is meant for interoperability, where a call from the "Adapter interface" should be translated to a call to the "Adaptee Interface", in order to "plug" the calls transparently, so to speak. Bridge interface is meant for data extraction, or data combination, depending on the need. It's a bridge abstraction, relying on a implementor contract, to provide methods to access data, no matter what the implementation is.
Thank you. I read the 'Design Patterns' chapter on Bridge and really couldn't understand how this was different from simple delegation or what problem it was actually trying to solve. I don't know if your interpretation is precisely the problem they are trying to solve, but it certainly gives me a good way of thinking about it that makes sense.
You rock, man! From what videos of yours I have seen, you offer very lucid and memorable explanations of design patterns. I especially appreciate that you show your own process of understanding--this saves us or greatly lightens a learner's process needed to reach the moment of clarity when we understand a concept in our own mental framework and can then see potential as to how we could use it in our own circumstances. That is, you take the process down to your personal level, a level we eventually have to take learning--this much better than tossing us data somewhat like a Wikipedia article for us to ponder...and ponder, i.e., "leave it to the reader to figure out". In other words, you help us to faster reach paths in our own way of understanding by walking through your own paths and sometimes how you got there. Thank you!
First I just compared the length of your videos and the other pattern videos and thought " that's ridiculous" but, you sir managed to imprint it in my brain perfectly. You don't just explain well you do it in a way that sticks (Just like the head first books do). Kudos!
Cannot easily agree that resource is an implementation of a view (abstraction) Yet appreciate the effort to give a 🆒 real life examples explanation that is rich in context and easy to follow!
Very good point! Thanks :) It might make a bit more sense if we think about it as View (abstraction) and ResourceSpecificView (implementation), but again, this isn't *really* true because the latter *is* not actually a view, it is a resource. So I agree with you 100%. Imho it is the idea of decoupling the abstraction from the implementation (i.e. the usage of the terms abstraction/implementor) that is the culprit here. But I may definitely be wrong so hopefully I will come across some better example in the future :) Thank you very much for your comment! Very interesting :) And thanks for watching :)
This was the first video of yours that I have watched and you presented it very well. I was reading about this pattern for hours and couldn't really grasp it but with your help I think I have obtained a pretty solid grasp of it. Thank you!
Thanks. Now that I know what the Bridge pattern is, I see I've been using it for years. :) I guess it's one of those patterns that evolves naturally when you start holding references to interfaces instead of actual classes.
Omg I'm editing the upcoming video currently and I make exactly that statement in the video :) I.e. that the bridge pattern probably is a natural evolution/conclusion from simply programming to interfaces/abstractions. So I couldn't agree with you more :) :) Thanks for watching and for sharing :) :)
This actually is the best pattern at least to understand abstraction. I also understood the use of Interfaces really well when I understood this pattern.
Thank you! Really nice and clean explanation. I totally agree that the definition in the book is quite confusing but thanks to you I got the idea completely.
Hey Christopher, this one of the best explanations and examples I have ever come across on Bridge pattern. Thanks much for your efforts and a wonderful brain storming tutorial
I love the way you explains the difference between Adapter and Bridge Pattern. Hope to see more videos may be some the real life application where we can fit different patterns.
Great way of explaining the design pattern. I understood the example but as you said at the end, it would be great if you could also list few other scenarios where this pattern would be applicable.
Thank you, Christopher, it is really awesome, the way you explain using the real-world example. because of that only I was able to connect it to the problem that I faced before.
Just one thing that can makes easier and a small correction on what you mentioned on 36:45 of the video above. The thing is the views are dependent to the resource. The views can be taken as a view for smart phone, tablet and a normal computer display (for the sake of resolution mainly). These views are dependent to resources, while resources has no dependencies to these different types of display. That is a good example for Bridge pattern on why Front-end and Back-end are kept separately. Thanks :)
I love this explanation for the Bridge design pattern, I've recently been strugling with some sort of similar issue and as long as the requirements grow I'm having a large cartesian product underlying in my implementation. I will apply this particular design pattern in the short term :)
Finally I understood what is that Bridge pattern about! Thanks a lot! P.S. Understood it on the mark of 30-40% of the video, because I really used it already in my work, but didn't understand that I did.
I had to read Head First Design Pattern yrs ago I find it entertaining and effective, If I recall there was that girl that was anti-pattern which helps you question why you should use the pattern in the first place and understand it better.
2022 still the best design pattern videos!! I am really sad to see that you are not posting more videos like this that have you explain in a whiteboard very fundamental stuff! Really appreciate your teachings!!! Please comeback with topics like this! Love your whiteboard teachings!!
Your DP videos are seriously the best explanations anywhere. And I totally agree the definition of the bridge pattern is superconfusing. Especially because the “abstraction” in this case doesn’t need to be conceptually related to its “implementor”. Maybe I’m wrong but I see it as sort of a combination of template and strategy pattern.
It seems to me like this is an application of the strategy pattern, combined with the adapter pattern? (You mention this briefly in the video, but I would appreciate you going into more detail if possible). The way I see it, we have some objects (media) and we want strategies to display them (views). We kind of make "viewing strategies", i.e., long-form and short-form and we have "content provider strategies" i.e., the media resources which are adapters for the items of media into strategies for providing content. We have some sort of Window object or something, and we provide this Window with a View and a MediaResource. These are composed into a single media display window. This means that we don't need dozens of different classes for each pair of media and view we wanted to use (Cartesian product). The fact that the window passes the MediaResource to the View object is kind of a minor note in the end, I think, but it is the part that makes this the bridge pattern. It's a very good pattern to see... because it would not necessarily be obvious you could do this, but am I right in saying it seems to be a specific combination of strategy and adapter?
Actually I just tweeted something along the lines of "strategy + adapter" a few minutes ago :) :) :) So indeed, I do agree with you :) To me Bridge patterns seems like the Adapter pattern where the adaptee is an abstract strategy. Where, importantly (and as you say) the abstract adapter forces concrete adapters to accept an abstract strategy in the constructor (or rather: is dependency injected some way). Great comment! Thank you, and thank you very much for watching :)
I am not agreeing to your comment "strategy+adapter" = "bridge".From your example , Choosing LongFormView,ShortFormView involves strategy pattern ..that is different .. here we are trying to decouple Views and Resource .. From your video i understood that bridge pattern can be used when we have cartesian product problem ..Correct me if i am wrong ..
I know this is a very old comment, but still : @@shanmugamsekar4044 I think what @Mark Chimes is trying to say is, even though the *intent* of these patterns differ, structurally bridge pattern looks like an adapter pattern whose adaptee is a strategy pattern. Rather, imagine an adapter pattern with the adaptee and target, both being interfaces. It looks structurally similar! Again, just my views.
Another great example of an application of this pattern would be the Spring MVC architecture, where views vary independently of the Model objects returned by various Controllers, and controllers are nothing but adapters of the database :)
Great thanks for making this series!! You make each pattern's goal and details super clear! One thing that upsets me regarding patterns is that i fail to see which patterns to apply when i am encountered with a real-life scenario. I mean sometimes i see a problem that needs to be solved, and my intuition says that it can be solved by using some pattern, but to pick correct pattern is pretty Hard...
I think the "intent" of each pattern is what helps to choose the "right" one. If you trying to restrict access to something, you probably should use Proxy If you trying to simplify use, you probably should use Facade If you trying to avoid class explosion, you probably should use Decorator Also, I believe there's no *right* one. There's only the pattern that solves the problem, create few ones and works for the team
I was able to codify in .net this pattern thanks to you, very simple pattern indeed, once you get the grasp of it. The explanations and definitions about it are hard / nonsense though. I went one step further and made the Bridge to implement a generic, so I can use the bridge to implement whatever interface, which whatever return type.
@@PoulJulle-wb9iu Actually in the design pattern books there's no such distinction. They are just implementation of abstractions, interface or classes. At least, that's what I remember but I'm not sure.
it's 2023 and this series is still amazing
100%
2020 now. Still the best design pattern videos I've watched.
same here
2021 now. Still the best design pattern video-series in the universe! Thanks for this 🙏
Guys, can anyone tell the difference between Strategy and Bridge? They seem so similar. Basically allow a class to define an implementation on runtime.
Strategy is about encapsulating and plugging-in a behavior... But isn't Bridge doing the same here? The ConcreteImplementors are basically the strategies. What's the difference?
@@JerryOmann Same here.
Just try to understand which type of problem both design pattern solve, you will understand difference
Thanks, the best design pattern tutorials on YT!
So glad to hear that you're expanding this series from its original scope. This is an excellent series, actually useful as a learning resource. Thanks a lot for your time dude, and really good job so far. :)
Thank you! And thank you for your very encouraging words of understanding. Helps to keep me going :) Thanks for watching.
Great work dude !
So. Worst ...video should be very short 5-8 mins .. should explain 1 1pattern in 1 video.. explain btech syllabus..
I've be developing software for 23 years and, have read both books, and know and have used all of these patterns. I came looking for good tutorials for my less experienced team members, and even with knowing this information already, I can't stop watching these, they are excellent resources.
Very happy to hear that. Thanks for sharing 😊🙏
00:03 The bridge pattern is a part of the additional patterns mentioned in the book Design Patterns.
01:48 The bridge pattern decouples an abstraction from its implementation.
06:10 The Bridge Pattern decouples abstraction from implementation.
08:30 The Cartesian product is a new set of all combinations of two sets.
13:01 Different views and media types need to be handled in a flexible manner.
15:13 The bridge pattern allows combining any arbitrary resource with any arbitrary view.
19:14 Using the Bridge pattern reduces the number of classes needed to handle different combinations.
21:23 The bridge pattern allows us to isolate the specifications of artist resources and view nests.
25:43 The Bridge Pattern allows views to use specific methods from resources without breaking the interface segregation principle.
27:52 Avoid duplicating behavior across different resources.
31:38 The resources in the bridge pattern have different concretions.
33:31 A view in the Bridge pattern can access a resource that behaves as a resource.
37:17 Separating artist specific, book specific, and playlist specific functionalities into their own inheritance hierarchy.
39:14 The video discusses the Bridge Pattern in design patterns.
42:54 An artist resource implemented the interface IResource and adapted over an artist.
44:46 The artist resource needs to delegate to a specific artist to get the required information.
48:37 The Bridge pattern allows for separating platform-specific and platform-independent code.
50:34 The bridge pattern allows a view to ask a resource for the information it needs to construct a particular view.
King 👑
Bridge pattern is used in creating custom item recyclerview in android.
Custom item recyclerview means that the recyclerview can contain different items like tiles, buttons, text.
When I first saw the custom recyclerview implementation in an actual codebase, it took me a lot of time to understand how it was working, but when I did, I was able to appreciate its beauty.
I have only just now realized that it was bridge pattern used in custom recyclerview and things are more clear.
Huge thanks Chris for compiling such an amazing playlist. Your way of teaching is commendable.
I will probably never thank you enough for these videos...! You explain things so clearly, I can spend days understanding a pattern then I watch your video and it just clicks and suddenly it's all clear. Thank you!!
I watch your tutorial when i was an intern employee, now as a senior level still watching your stuff. Appreciate it!
Congratulations on the growth! And thanks for watching 😊🙏
The real thing about your explanations is that it's ok to be shortly distracted watching your video without loosing my train of thought.
It's not necessary to be being in the full attention during whole video as in the case of classic university lectures.
It's super helpful and the best thing for me.
You're like the Mr. Bean of programming ;D Great work - and as you would say, super-pedagogical example! :-)
Hahaha I have actually heard the Bean comparison before so I guess it must be true :) :) :) Anyways, thank you for the kind words and for watching the series :)
2022 now. Still the best design pattern videos man
Thanks!
Thank you 😊
Watched this in 2020 and 2024. Gold quality resource 😊
Even though this playlist is 5-6 years old still the best out there. Thank you for this golden playlist.
The best teacher of design patterns till now .
I am saved by this video... all 52 minutes with it
I learned from lot's of tutor all they do their best , but you are the best teacher, ...in starting I hate designed patterns because I didn't understood but after learning from I am fall In love with design pattern 😍💕
Thank you very very much! I would never have imagined that I could understand patterns so deeply! You are the best teacher ever, really!!
There is no word to describe how grateful I am to you for these videos
This is literally the best design patterns video I ever watched on UA-cam
Love the sound effects of heads exploding.
Understood it about half way thru the example. Excellent explanation, can't wait for a reason to use it.
Brilliantly explained.. thanks alot.. uml n pseudo code makes it more clear...
I watch your design patterns videos before breakfast and even before i return to bed at night, excellent job
The best ever explanations of design patterns! You are awesome man! Please just don't stop recording new episodes. And your "code walk" series is really about those things that every programmer should think about. Do as many as possible, please :)
I cant express how great you have explained this. 10 min into the video and I already understand it better than by any videos or tutorials I watched or read before. Thanks!
It's 2024, I was really confused about design patterns and your videos have cleared my concepts. Thanks!
I love your voice and you as a person
Thank you :) And thank you for watching :)
Hes faqin amazing!
Last moments of 2020, still the best design pattern explanations. Thank you master.
This has to be the hardest of all the patterns covered in this series yet. Will watch it twice. Thanks a lot for creating this series.
You're awesome!
With your explanation, anyone has a grasp of Design Pattern.
Thank you!
This comes together exactly at 15:16. Very nicely explained.
king of design pattern tutorials
Last time I watched your videos about 5-6 years ago and till now I watched a lot of other videos related to software engineering, but never saw someone explaining not like you, but even close to you.
I bet this is the best explanation of the bridge pattern all over the youtube
I would definitely recommend this series for learning Design Patterns to any friends and colleagues.
Thanks!!!
I finally found a good example of how to apply this pattern. Very good explanation for the pattern.
Shout out from 2023! Thanks for taking the time to make these super helpful videos
This is literally the best video/explanation i ve seen about this topic (bridge)
The enlightenment/ the moment of Ahaa happened to me at 23:40 of this video. Thanks a lot!
This is what I call talent. Best explanation ever. Thx man!
Great Job man! This serie is a success
+konzinov maverick Thank you for the encouragement. I'm glad to hear :) Thanks for sticking with it :)
Man, you are making the programming more funny than before. The best tech video I have ever seen. Thanks for the all series.
Thanks a lot! Glad you find the channel useful :)
I wish I had found this channel before because I never really understood this subject before I heard from this guy, thank u so so much!
Thats another great video. I love your explanations.
Basically i would differentiate Bridge Pattern from Adapter pattern as the following:
Adapter pattern is meant for interoperability, where a call from the "Adapter interface" should be translated to a call to the "Adaptee Interface", in order to "plug" the calls transparently, so to speak.
Bridge interface is meant for data extraction, or data combination, depending on the need. It's a bridge abstraction, relying on a implementor contract, to provide methods to access data, no matter what the implementation is.
This is my second revision of this series and again I'll say what an explanation!!!! Great job bro...
as well as the previous patterns, you've provided best description.
Thank you. I read the 'Design Patterns' chapter on Bridge and really couldn't understand how this was different from simple delegation or what problem it was actually trying to solve. I don't know if your interpretation is precisely the problem they are trying to solve, but it certainly gives me a good way of thinking about it that makes sense.
You rock, man! From what videos of yours I have seen, you offer very lucid and memorable explanations of design patterns. I especially appreciate that you show your own process of understanding--this saves us or greatly lightens a learner's process needed to reach the moment of clarity when we understand a concept in our own mental framework and can then see potential as to how we could use it in our own circumstances. That is, you take the process down to your personal level, a level we eventually have to take learning--this much better than tossing us data somewhat like a Wikipedia article for us to ponder...and ponder, i.e., "leave it to the reader to figure out". In other words, you help us to faster reach paths in our own way of understanding by walking through your own paths and sometimes how you got there. Thank you!
First I just compared the length of your videos and the other pattern videos and thought " that's ridiculous" but, you sir managed to imprint it in my brain perfectly.
You don't just explain well you do it in a way that sticks (Just like the head first books do).
Kudos!
I was confused about the bridge pattern but now it's 100% clear ! thanks ! please continue this series
Cannot easily agree that resource is an implementation of a view (abstraction)
Yet appreciate the effort to give a 🆒 real life examples explanation that is rich in context and easy to follow!
Very good point! Thanks :) It might make a bit more sense if we think about it as View (abstraction) and ResourceSpecificView (implementation), but again, this isn't *really* true because the latter *is* not actually a view, it is a resource. So I agree with you 100%. Imho it is the idea of decoupling the abstraction from the implementation (i.e. the usage of the terms abstraction/implementor) that is the culprit here. But I may definitely be wrong so hopefully I will come across some better example in the future :) Thank you very much for your comment! Very interesting :) And thanks for watching :)
As I am currently preparing for an exam I have to thank you a lot for the Spotify example. That made the whole concept so obvious to me. Mind blown!
2022 now. Still the best design pattern videos I’ve watched.
Thank you for making such valuable videos. These are going to be a great resource for developers.
+sovan misra Thanks! I'm glad to hear. We'll see if they'll stand the test of time :) :) Thanks for watching! :)
Still 2024 and I watched all of your design pattern videos❤
This was the first video of yours that I have watched and you presented it very well. I was reading about this pattern for hours and couldn't really grasp it but with your help I think I have obtained a pretty solid grasp of it. Thank you!
Thanks. Now that I know what the Bridge pattern is, I see I've been using it for years. :) I guess it's one of those patterns that evolves naturally when you start holding references to interfaces instead of actual classes.
Omg I'm editing the upcoming video currently and I make exactly that statement in the video :) I.e. that the bridge pattern probably is a natural evolution/conclusion from simply programming to interfaces/abstractions. So I couldn't agree with you more :) :) Thanks for watching and for sharing :) :)
Great explanation! also, the video starts at 2:45
This actually is the best pattern at least to understand abstraction. I also understood the use of Interfaces really well when I understood this pattern.
Best explanation I have found so far. great work man
Great video. Suprised these aren't getting more views. I'm learning so much.
Thanks :) I'm glad to hear. Feel absolutely free to share the video with friends ;) :)
Man I finally understand this pattern. It is actually extremely simple but it was described in such a confusing way at my university. Great job!
my prof recommended this video as a part of her lessons. this is honestly much better.
I’m very glad to hear this is used in class as I use it in class myself 😊😊 Thanks for sharing and for watching 😊
Thanks Christopher Okhravi. It is interesting. Your explanation is in sync with my thought process.
You are really amazing, I even don't have words to explain How amazing your way of teaching is. I'm totally inspired by you.
Thank you! Really nice and clean explanation. I totally agree that the definition in the book is quite confusing but thanks to you I got the idea completely.
Read both books but I still prefer the video demonstration ... Simply Most Amazing Simplified Design Pattern Videos !!!
this is an absolutly prefect explanation for this design pattern. good job!
Hey Christopher, this one of the best explanations and examples I have ever come across on Bridge pattern. Thanks much for your efforts and a wonderful brain storming tutorial
Awesome as always, now I understand what is Bridge pattern about. Eagerly waiting for your next videos. Thanks you again.
Somehow I managed to understand Bridge pattern - perfectly clear. I did not have Heads first book... Thank you for the lectures!
New schedule is exciting! Thank you guy!
+Houjing Huang Glad to hear :) Thanks for watching :)
Great videos Christopher! I really like all of them! It helped me a lot to understand these patterns through your examples and explanations!
I love the way you explains the difference between Adapter and Bridge Pattern. Hope to see more videos may be some the real life application where we can fit different patterns.
2021: Still the best resource for Design Patterns!
Love your efforts man! 🤓🙌
exactly
Great way of explaining the design pattern. I understood the example but as you said at the end, it would be great if you could also list few other scenarios where this pattern would be applicable.
Thank you, Christopher, it is really awesome, the way you explain using the real-world example. because of that only I was able to connect it to the problem that I faced before.
Just one thing that can makes easier and a small correction on what you mentioned on 36:45 of the video above. The thing is the views are dependent to the resource. The views can be taken as a view for smart phone, tablet and a normal computer display (for the sake of resolution mainly). These views are dependent to resources, while resources has no dependencies to these different types of display. That is a good example for Bridge pattern on why Front-end and Back-end are kept separately. Thanks :)
I love this explanation for the Bridge design pattern, I've recently been strugling with some sort of similar issue and as long as the requirements grow I'm having a large cartesian product underlying in my implementation. I will apply this particular design pattern in the short term :)
Finally I understood what is that Bridge pattern about! Thanks a lot!
P.S. Understood it on the mark of 30-40% of the video, because I really used it already in my work, but didn't understand that I did.
Fantastic pattern! Fantastically presented!
You are The God of explanation
Amazing explanation. Very Clear and engaging. Thanks a lot Sir.
I had to read Head First Design Pattern yrs ago I find it entertaining and effective, If I recall there was that girl that was anti-pattern which helps you question why you should use the pattern in the first place and understand it better.
I hope you'll continue with the serie of patterns, it's very useful and you have a very didactive way to explain. Great video.
Hej ! Your videos are really helpful. You can describe design patterns in really clear and simply way. Keep recording becouse this is gold :) Cheers !
2022 still the best design pattern videos!! I am really sad to see that you are not posting more videos like this that have you explain in a whiteboard very fundamental stuff! Really appreciate your teachings!!! Please comeback with topics like this! Love your whiteboard teachings!!
Simply brilliant!
Your DP videos are seriously the best explanations anywhere. And I totally agree the definition of the bridge pattern is superconfusing. Especially because the “abstraction” in this case doesn’t need to be conceptually related to its “implementor”. Maybe I’m wrong but I see it as sort of a combination of template and strategy pattern.
You are great man, thank you from Egypt
Thanks a lot ! This is an extraordinary explanation
2022 now, still the best 😉 congratulations on the good job!
It seems to me like this is an application of the strategy pattern, combined with the adapter pattern? (You mention this briefly in the video, but I would appreciate you going into more detail if possible).
The way I see it, we have some objects (media) and we want strategies to display them (views). We kind of make "viewing strategies", i.e., long-form and short-form and we have "content provider strategies" i.e., the media resources which are adapters for the items of media into strategies for providing content. We have some sort of Window object or something, and we provide this Window with a View and a MediaResource. These are composed into a single media display window. This means that we don't need dozens of different classes for each pair of media and view we wanted to use (Cartesian product). The fact that the window passes the MediaResource to the View object is kind of a minor note in the end, I think, but it is the part that makes this the bridge pattern.
It's a very good pattern to see... because it would not necessarily be obvious you could do this, but am I right in saying it seems to be a specific combination of strategy and adapter?
Actually I just tweeted something along the lines of "strategy + adapter" a few minutes ago :) :) :) So indeed, I do agree with you :) To me Bridge patterns seems like the Adapter pattern where the adaptee is an abstract strategy. Where, importantly (and as you say) the abstract adapter forces concrete adapters to accept an abstract strategy in the constructor (or rather: is dependency injected some way). Great comment! Thank you, and thank you very much for watching :)
Ah, I see, haha. I should follow you on Twitter. @chrokh
Thank you for typing that I want to say:)
I am not agreeing to your comment "strategy+adapter" = "bridge".From your example , Choosing LongFormView,ShortFormView involves strategy pattern ..that is different .. here we are trying to decouple Views and Resource .. From your video i understood that bridge pattern can be used when we have cartesian product problem ..Correct me if i am wrong ..
I know this is a very old comment, but still : @@shanmugamsekar4044 I think what @Mark Chimes is trying to say is, even though the *intent* of these patterns differ, structurally bridge pattern looks like an adapter pattern whose adaptee is a strategy pattern. Rather, imagine an adapter pattern with the adaptee and target, both being interfaces. It looks structurally similar!
Again, just my views.
Another great example of an application of this pattern would be the Spring MVC architecture, where views vary independently of the Model objects returned by various Controllers, and controllers are nothing but adapters of the database :)
Great thanks for making this series!! You make each pattern's goal and details super clear! One thing that upsets me regarding patterns is that i fail to see which patterns to apply when i am encountered with a real-life scenario. I mean sometimes i see a problem that needs to be solved, and my intuition says that it can be solved by using some pattern, but to pick correct pattern is pretty Hard...
I think the "intent" of each pattern is what helps to choose the "right" one.
If you trying to restrict access to something, you probably should use Proxy
If you trying to simplify use, you probably should use Facade
If you trying to avoid class explosion, you probably should use Decorator
Also, I believe there's no *right* one. There's only the pattern that solves the problem, create few ones and works for the team
2023 and this is still the best resource for design pattern
That's a wonderful explanation!
This is awesome 🎉🎉🎉 Thank you for your effort 😊
I was able to codify in .net this pattern thanks to you, very simple pattern indeed, once you get the grasp of it. The explanations and definitions about it are hard / nonsense though. I went one step further and made the Bridge to implement a generic, so I can use the bridge to implement whatever interface, which whatever return type.
The arrow when implementing an interface is a dashed line. Other than that, it seems right on to me.
idk how he misses that consistently
@@PoulJulle-wb9iu Actually in the design pattern books there's no such distinction. They are just implementation of abstractions, interface or classes. At least, that's what I remember but I'm not sure.