8 Design Patterns EVERY Developer Should Know

แชร์
ฝัง
  • เผยแพร่เมื่อ 21 ม.ค. 2025

ความคิดเห็น • 473

  • @NeetCode
    @NeetCode  ปีที่แล้ว +268

    ✅ In-depth OOP Design Patterns course: neetcode.io/courses/design-patterns
    ✅ OOP Interviews course: neetcode.io/courses/ood-interview

    • @chair_smesh
      @chair_smesh ปีที่แล้ว +22

      I love you..err I mean thank you

    • @yt-sh
      @yt-sh ปีที่แล้ว +4

      need more on functional programming tho

    • @TonInter
      @TonInter ปีที่แล้ว +7

      Loved Careless whisper. I say keep 'em coming!

    • @sarcasmasaservice
      @sarcasmasaservice ปีที่แล้ว

      Personally I really enjoyed the video and the humor but because of the vulgarity I cannot share it with my students which I find disappointing. You did such good job of providing nice, succinct overviews of the patterns it would have made a great resource for them.

    • @yli8888
      @yli8888 ปีที่แล้ว

      I love the simple code expression to illustrate a rather abstract concept - pattern ❤ thank you for the great work.

  • @jse-shack825
    @jse-shack825 ปีที่แล้ว +1753

    A cool thing happens if you learn programming by yourself: after some time you start to implement these patterns without knowing them formally. Most often they are more clumsy than the original but the spirit is there. Really cool how patterns are just a result of efficient and modular thinking.

    • @metaverse413
      @metaverse413 ปีที่แล้ว +51

      That is so true.

    • @markoates9057
      @markoates9057 ปีที่แล้ว +19

      factory that builds factory is no surprise - design patterns have emerged for a reason, they're composable in that way.

    • @jeffparent2159
      @jeffparent2159 ปีที่แล้ว +18

      The hope though is that you eventually learn the terms so that when a design is handed to you with just design patterns you understand what is going on.

    • @wilsonemmanuel1352
      @wilsonemmanuel1352 ปีที่แล้ว +17

      This is me. Understanding how it works without even know the patterns have names

    • @jse-shack825
      @jse-shack825 ปีที่แล้ว +20

      @@edukee also true. At times you have to ask yourself if it is worth coding a whole embedded abstraction layer combined with high level OOP to turn on an LED just because somebody on youtube told you to. The boring but general answer is: there is no universal approach. Different applications require different styles.

  • @AmrithaS-f4w
    @AmrithaS-f4w ปีที่แล้ว +23

    🎯 Key Takeaways for quick navigation:
    00:54 Creational *Pattern - Factory: Use a factory to instantiate objects like ordering a burger, specifying the type of object you want without worrying about its creation details.*
    01:40 Creational *Pattern - Builder: For more control over object creation, use the builder pattern. It involves individual methods for adding components and a build method to create the final object.*
    02:37 Creational *Pattern - Singleton: Ensure a class has only one instance. Useful for maintaining a single copy of application state with a static method to retrieve the instance.*
    03:47 Behavioral *Pattern - Observer (Pub-Sub): Implement real-time updates by having a subject (e.g., TH-cam channel) maintain a list of subscribers and notify them of events. Subscribers implement an interface for event handling.*
    05:24 Behavioral *Pattern - Iterator: Define a pattern for iterating through values in an object. Useful for simple arrays or more complex structures like linked lists.*
    06:32 Behavioral *Pattern - Strategy: Modify or extend a class's behavior without changing it directly. Define strategies (e.g., filters) as implementations and pass them to the class at runtime.*
    07:25 Structural *Pattern - Adapter: Make incompatible interfaces compatible. For example, create an adapter to make a micro USB cable fit into a standard USB port.*
    08:34 Structural *Pattern - Facade: Use a wrapper class (facade) to abstract lower-level complexities, providing a simpler interface for programmers to interact with.*
    Made with HARPA AI

    • @iciclearms
      @iciclearms หลายเดือนก่อน

      I love you

  • @Comet0529
    @Comet0529 ปีที่แล้ว +26

    This was a good introduction! I will say, because they are the usually the most talked about, there are some things that are worth elaborating further on in regard to creational design patterns:
    Factories aren't just about fabricating objects. One of the big advantages is that they disconnect how an object is made from where it might be needed to be created. The best part of factories are that they can be instantiated and shared and passed between code. Otherwise, they're just a set of default constructors. They're often considered outdated because most languages have first class functional support these days. A function that takes no arguments and returns a new thing when called can usually be passed around. This is essentially the same as a factory.
    Builders aren't necessarily identified by their methods that can be easily chained. You can have builders that don't do this and they're still a builder. They're useful, like the factory, for when you have pass them around to other code. For example, you might have a lot of code that wants a say in how an object is created. It lets you spread the logic for how something is created over multiple places and build it once everything has had its input. It also lets the final result be immutable if you would prefer, making it mutable during creation and allowing for the resulting object to say "no more changes!"
    Singletons are great but hard to test. Best practice is to make a singleton extend some kind of interface class and provide the instance to the code that needs it, either as-is or via a factory. This lets you swap it out when you do testing. Otherwise, you're locked into always using that global state in your tests and it gets harder to work with!

  • @Ryukachoo
    @Ryukachoo ปีที่แล้ว +97

    Been putting off reading head first design patterns for a long time.
    This seems like an excellent intro to each concept that I can now find more references to

    • @blackplaydoh3522
      @blackplaydoh3522 ปีที่แล้ว +2

      Personally, I don’t consider ‘Head First’ a good intro. Many examples in that book make little sense and descriptions are too verbose at times even for simplest terms.
      I’d suggest as an intro finding a retelling of that book as a course or video playlist.

    • @marcs9451
      @marcs9451 ปีที่แล้ว +5

      tbh the book isn't really worth it, just like SOLID and "Clean Code" these things have been hailed as bibles when in most cases they only patch problems that are inherent to OOP. Or they make up problems and pretend to solve them (SOLID principles especially)

    • @jesserebel
      @jesserebel ปีที่แล้ว

      @@marcs9451 do you have any resources for better programming? ive been going down the rabbit hole of trying to learn the right concepts since ive gotten into c#. whereas my whole past has been nothing but functional programming. seems like everyone holds these couple of books religiously when they are outdated? so where does a developer start?

  • @blackplaydoh3522
    @blackplaydoh3522 ปีที่แล้ว +206

    Nice refresher.
    On the topic of GoF patterns, many of them may seem outdated or unnecessary for inclusion as patterns because for modern developers many of these patterns are even included at language level as basic features, however, it was much different back then when OOP was just taking off in enterprise world.

    • @notoriouslycuriouswombat
      @notoriouslycuriouswombat ปีที่แล้ว +9

      yep, this mostly seems like a nice tutorial about history times

    • @Brlitzkreig
      @Brlitzkreig ปีที่แล้ว +6

      Yes, but I guess it's still valuable to be able to learn the concepts and understand them

    • @juanacosta723
      @juanacosta723 ปีที่แล้ว +2

      This! And also, a lot of GoF patterns are now outdated in most used languages thanks to multi-paradigm approach which include functional programming (where GoF is a base feature)

  • @vhbatistela
    @vhbatistela ปีที่แล้ว +45

    NeetCode is to coding to what The Organic Chemistry Tutor is to all school subjects, everything is clear and easy to understand when you guys teach it!!

  • @RaveKev
    @RaveKev ปีที่แล้ว +30

    I'm a Java developer since 2008, and I LOVE your punches towards Java 😍 they are to much fun and true

    • @jsvrs
      @jsvrs 5 หลายเดือนก่อน

      Are you still Java frontend developer?

    • @RaveKev
      @RaveKev 4 หลายเดือนก่อน

      @@jsvrs I still develop with Java (don't know how the Frontend came into your comment). But since 3 years I only develop Java as a hobby.
      3 years ago I switched to develop professionally with a LowCode platform called OutSystems in my company and I love it!

  • @user-yr1uq1qe6y
    @user-yr1uq1qe6y ปีที่แล้ว +29

    As you touched on with pub/sub for Observer patterns, naming can be an issue. As a developer with decades experience it can be a challenge when these patterns are “rediscovered” and given new names. This probably wouldn’t happen if people truly understood the patterns instead of memorizing the fancy name de jour for them.

    • @whossname4399
      @whossname4399 ปีที่แล้ว +7

      My understanding is pubsub is different to observer. The distinction is that observer calls the listeners directly in code, so the listeners are guaranteed to receive the message. In pubsub it is separate programs communicating with each other, often on separate computers over a network. This means that in pubsub you need to think about how the subscriber should behave if it misses a message, this isn't a consideration for the observer pattern.

    • @whossname4399
      @whossname4399 ปีที่แล้ว

      Just saw the code. This looks like the observer pattern, not pubsub to me.

    • @user-yr1uq1qe6y
      @user-yr1uq1qe6y ปีที่แล้ว +2

      @@whossname4399 The same pattern, no networks involved, was described as event subscribers in the early days of event driven programming. If I recall the Borland OWL and maybe even Turbovision used these terms. It may be the terms are being refined over time to be more specific.

    • @whossname4399
      @whossname4399 ปีที่แล้ว

      @@user-yr1uq1qe6y hmm. Another distinction is I've only really seen the observer pattern described in the context of heavily object oriented code (I've been working with mostly functional code for the last 5 years), where as I've mostly seen pubsub in the context of network communication. I can see how the two are similar, but they really seem like different things to me. I don't even know if I think of pubsub as a "pattern".

    • @user-yr1uq1qe6y
      @user-yr1uq1qe6y ปีที่แล้ว

      @@whossname4399 It’s been so long since I dove into the gof design pattern stuff that I looked up the observer pattern wiki. It mentions pub/sub as a component of the pattern. The distinction does seem to be somewhere in who owns the list of observers (subscribers). Wish the day job still allowed us to spend official time on this type of thing!

  • @riyanahmed6657
    @riyanahmed6657 ปีที่แล้ว +74

    This makes more sense than the semester long course I had on design patterns

    • @Naomikho
      @Naomikho ปีที่แล้ว +4

      Ikr, I wish this video was here when I was studying in uni.

    • @marcusplenty1153
      @marcusplenty1153 ปีที่แล้ว

      He legit one of the best to do it when it comes to explaining these type of problems. How google rejected this man once is beyond me

    • @SisypheanRoller
      @SisypheanRoller ปีที่แล้ว

      You had a course on design patterns wtf

  • @samuelmayna
    @samuelmayna ปีที่แล้ว +15

    Analogies are on point. Great work.

  • @DrewTNaylor
    @DrewTNaylor ปีที่แล้ว +19

    The facade reminds me of some subs/functions that I have in one of my libraries that are too dangerous to handle directly so I added safer wrapper subs/functions around it, which can each be used depending on the required features. It's also kinda like a factory, but not quite.

  • @phillipgilligan8168
    @phillipgilligan8168 ปีที่แล้ว +10

    Hey NeetCode, thanks for the succinct breakdown of these patterns. I am an engineer, but not a dev, and don't really use these patterns, but in areas such as IaC just as an example, it's interesting to think about how I could implement concepts introduced in these patterns. Loved your analogies so I could visualize these concepts better. Thanks!

    • @nevdread1488
      @nevdread1488 ปีที่แล้ว

      Hello sir, I am looking for CS intership oportunity. My qualification are 9 cgpa (till 5th semester)skills DSA ,DAA, python(django, machine and deep learning), Java, HTML , CSS , JavaScript . I hope to hear from you soon.

    • @TragicGFuel
      @TragicGFuel 8 หลายเดือนก่อน +1

      @@nevdread1488 I will never take an Intern that spams public comment sections

    • @Kabir-dv6xb
      @Kabir-dv6xb 2 หลายเดือนก่อน

      @@TragicGFuel Lmaoo

  • @thomasmendez4969
    @thomasmendez4969 ปีที่แล้ว +20

    Appreciate you breaking it down so thoroughly while making it easy to understand!
    Remember working with a senior engineer who would talk about a few design patters he implemented but he couldn't always explain it effectively. This was very well done! Motivated to get back to learning these patters on my own now! Thanks!

  • @darkwoodmovies
    @darkwoodmovies ปีที่แล้ว +10

    I use these but never really bothered to learn the formal definitions. Seems a bit dated in today's patchwork of random NPM libraries engineering, but still fun to finally link the names to the faces!

  • @arminmatthes
    @arminmatthes ปีที่แล้ว +14

    Knowing these patterns is only one side of the coin. What's more important is really understanding when (and when not!!!) To use them, especially in production code.
    I used to put singletons everywhere, feeling like a rockstar. And then, I learnt about SOLID and what can I say... In hindsight, singletons are a huuuuuge anti-pattern for all but the most edgy of the edge cases.

    • @johannesgupta
      @johannesgupta ปีที่แล้ว +1

      Basically, it really is only app state or no singletons at all - except if your app works with some kind of resources, such as device drivers, when wrapping the device client into a singleton is really important

    • @arminmatthes
      @arminmatthes ปีที่แล้ว +1

      @@johannesgupta sure, there are situations where wrapping something in a singleton is safer. But even If I absolutely have to use a singleton for some reason I would always stick to SOLID principles and pass the singleton instance using dependency injection instead of fetching it through the static class everywhere.

    • @johannesgupta
      @johannesgupta ปีที่แล้ว

      @@arminmatthes ofc

  • @adityasahu5318
    @adityasahu5318 ปีที่แล้ว +4

    Thanks man you explained it so well I am never gonna forget. Please keep posting videos like this. 👍

  • @thomash4810
    @thomash4810 ปีที่แล้ว +1

    Please never stop making videos. You have a gift for teaching. Your S-tier ability to explain topics is amazing.

  • @Nunoflashy
    @Nunoflashy ปีที่แล้ว +3

    Hahah 7:30, that subtle music along with the example, and then immediately giving another example saying "or maybe an example you're more familiar with", implying most programmers don't... ya know. Perfect.

  • @xylh5085
    @xylh5085 ปีที่แล้ว +6

    As someone who is going through the basics of Python, I'm pleased to see how much easier it is to play with data structures

    • @w花b
      @w花b ปีที่แล้ว

      It's pretty hard to do more high level than python without straight up switching to English or something like that

    • @xylh5085
      @xylh5085 ปีที่แล้ว +1

      Out of a sort of immaturity, I spent many years wasting time learning fundamentals the hard way with C of all languages (facepalm). I have a certain level of literacy from that, but now I have a lot of bad habits to unlearn. Python or perhaps JavaScript would have been the sane choice for many of the projects I worked on, upon reflection.

    • @vitalyl1327
      @vitalyl1327 ปีที่แล้ว

      @@w花b huh? Python is a low level language.

    • @tldoesntlikebread
      @tldoesntlikebread ปีที่แล้ว

      @@vitalyl1327 I'm pretty sure it's a high-level language, C is a low-level language, afaik they use C/C++ for some libraries in Python.

    • @vitalyl1327
      @vitalyl1327 ปีที่แล้ว

      @@tldoesntlikebread relative to C, Python is higher level language. On the whole continuum of language, Python is still on the very low level side. More so, Python is deliberately low level, as it discourage constructing higher level abstractions as something "un-Pythonic". It is built around all the same structural control flow constructions as the other low level languages and does not allow defining your own control flow or abstracting away from the very notion of control flow.
      Higher level languages allow to build embedded domain-specific languages on top of them with an arbitrary level of abstraction. Python explicitly does not allow to do so and discourage even this way of thinking on ideological grounds.

  • @notzarp
    @notzarp ปีที่แล้ว +1

    Love the vid! Much more concise than my CS Object Oriented class

  • @The8merp
    @The8merp ปีที่แล้ว +5

    This is a really nice video, well worth subscribing to this channel for. I hope you turn this into a series and cover more patterns in the future.

  • @Dyanosis
    @Dyanosis ปีที่แล้ว +1

    Having watched ArjanCodes and through years of coding experience - you could make your iterator "next" logic, @6:10, cleaner by doing an inverse check, like so:
    if not self.cur: raise StopIteration
    val = self.cur.val
    self.cur = self.cur.next
    return val

  • @jatinjainsecg988
    @jatinjainsecg988 ปีที่แล้ว +142

    It's great that u tried to make it more like the fireship videos ✌️

    • @evyats9127
      @evyats9127 ปีที่แล้ว +8

      What is great about trying to mimic the style of others?

    • @vijay.jaeger
      @vijay.jaeger ปีที่แล้ว +2

      Yesh it's just like @fireship. I'm happy both of my fav channels are coming together 😂🔥(entertainment and learning)

    • @Maniac-007
      @Maniac-007 ปีที่แล้ว +7

      @@evyats9127 so design patterns should only be used by the GoF dudes? We can’t follow their design patterns? 💀

    • @Kamkean
      @Kamkean ปีที่แล้ว +8

      @@evyats9127 that is literally what youtube is, people building on eachothers styles and ideas, you’re not making a good or intelligently designed criticism

    • @XxSgtSkittlesxX
      @XxSgtSkittlesxX ปีที่แล้ว +10

      Fireships videos are not very educational and way too memey imo.

  • @GospodinStanoje
    @GospodinStanoje ปีที่แล้ว +1

    One great example od a Facade class that I insantly understood after is "gcc".
    You can assemble if you like with "as" or link with "ld" or "cpp" to see the macros expand, but you can just use "gcc" and get all of this done.

  • @eldavimost
    @eldavimost ปีที่แล้ว +2

    If only I could give this video more than just one like.
    After a whole life reading and studying these patterns, I finally understand them thanks to this video!

    • @mazharuddin3647
      @mazharuddin3647 ปีที่แล้ว

      yeah you can, by creating multiple accounts lol

  • @antutucat8231
    @antutucat8231 ปีที่แล้ว +3

    Oh, we defiantly need a course on deign patterns from you

  • @ajith3530
    @ajith3530 ปีที่แล้ว +11

    This is really great stuff, I cannot tell you how much your videos have helped in solving questions while I am hunting jobs. The way you explain concepts with such intuitive examples is something I have not seen before. Please keep posting awesome content like this.

  • @gauravprabhu9572
    @gauravprabhu9572 ปีที่แล้ว +2

    Awesome explanation! This is a life-saver when it comes to quick brush before the interview! 😄Thank you so much for making this video!

  • @Refresh5406
    @Refresh5406 ปีที่แล้ว +16

    Laravel has a great implementation of the facade pattern. Basically, you can use it to statically proxy methods into any object, regardless of if it's a static or instance method. Super nice and simple.

    • @Davidlavieri
      @Davidlavieri ปีที่แล้ว

      facades are the most utterly offenders when it comes to shitty code

    • @Refresh5406
      @Refresh5406 ปีที่แล้ว

      @@Davidlavieri "the most utterly offenders" - Why would I take the coding preferences seriously of someone who can't construct a basic english sentence?

    • @UnknownString123
      @UnknownString123 ปีที่แล้ว

      ​@@Refresh5406 Maybe because english is the second language of a lot of people?

    • @stephenr85
      @stephenr85 ปีที่แล้ว

      ​​​​@@Davidlavieri separation of concerns often violates KISS and readability is somewhere in between, so there's a balance, and convenience patterns like Laravel's facades are very worthwhile in addition to serving the DRY principle effectively.

  • @beaulingpin
    @beaulingpin ปีที่แล้ว

    If I hadn't already subscribed, that "Please" at the end would have sold me. The content was good, too.

  • @deltoidx
    @deltoidx ปีที่แล้ว +2

    These examples are easy to digest and understand, great video

  • @bskyzzz
    @bskyzzz ปีที่แล้ว +1

    This is the best and simple explanation I've seen for design patterns, gg

  • @toast_salad
    @toast_salad ปีที่แล้ว +1

    you're great at teaching thank you for letting me brush up on my knowledge of these things

  • @lennonlink
    @lennonlink ปีที่แล้ว

    It was good that you disclosed your position in relation to JS, I can't trust no one that is align the madness of it! It's an important tool to know, but you don't have to love it.

  • @yandereSyndrome
    @yandereSyndrome ปีที่แล้ว +1

    The builder pattern is so interesting to me. The only reason for its existence that I can think of is that if you're working in a language that doesn't have language based solutions that make it easy to handle classes with many many parameters in their constructor, where a lot of them are optional or have default values. It's much easier to understand how to use the class by reading an example initialization that uses a builder pattern and only sets a few fields, compared to a constructor call of 10 elements where 7 of them are null. But if the language let me call constructors in a way that requires named parameters but also allows for optional parameters, I think the builder pattern loses its value.

    • @ratinhoembondeiro646
      @ratinhoembondeiro646 4 หลายเดือนก่อน

      True! Java and Kotlin are the perfect examples of both cases. But the builder pattern can teach you the mechanism behind it. And having a different construction syntax can open your mind to a different paradigm if you're observant enough. But I don't like having to implement it 😅

  • @Darios2013
    @Darios2013 ปีที่แล้ว +3

    Cool video! Jokes and examples made it more easy to understand

  • @minhluudinh5522
    @minhluudinh5522 ปีที่แล้ว +1

    this channel is gold.

  • @frbaucop
    @frbaucop ปีที่แล้ว

    Bonjour and many thanks for the video. Crystal clear, straight to the point, fun... Nothing to say except merci!

  • @yash1152
    @yash1152 4 หลายเดือนก่อน

    9:25 thanks a lot for sharing the catalog of other courses too 😃😉

  • @anshusharma11
    @anshusharma11 ปีที่แล้ว +1

    You never cease to amaze your viewers. Fantastic !!!

  • @fenryrtheshaman
    @fenryrtheshaman ปีที่แล้ว

    Worth noting that, in a language with singleton modules, one should usually use those instead of instantiating a class, as a singleton class is unintuitive and breaks assumptions one may have about classes

  • @licokr
    @licokr ปีที่แล้ว

    It's amazing. I really liked how easy and fun you taught about complicated concepts. Tbh, I need more explanation to understand some patterns though. I really appreciate it you made this video. Thank you very much!

  • @Ward1982
    @Ward1982 ปีที่แล้ว

    Very nicely laid out. Awesome vid

  • @CloudYeti
    @CloudYeti ปีที่แล้ว

    nice and simple explanations! I love that you use python examples. I finally grokked the strategy pattern.

  • @MrCleverOnion
    @MrCleverOnion 3 หลายเดือนก่อน

    Love the video, wish it was using a lower level language than python so you can really see how things are working behind the scenes

  • @Robdunnhill
    @Robdunnhill ปีที่แล้ว

    I’ve been watching videos like this for a while and a lot of it goes over my head. What should we learn first so these videos make more sense?

  • @Ross-ng4xl
    @Ross-ng4xl ปีที่แล้ว

    Great video. Super clear. Got me to sub. I'll be observing what you pub.

  • @davidemmanuel9418
    @davidemmanuel9418 ปีที่แล้ว +2

    Amazing that most programmers already implement most of these patterns without actually learning it. They just make sense! 😅

  • @yuurishibuya4797
    @yuurishibuya4797 ปีที่แล้ว

    Nice story linking. I guess why ppl forget the design patterns easily is due to lack of story to link them. Now it’s easier to remember Burger factory builder, or USB micro to mini adapter. And from this extract information.

  • @towatch
    @towatch 3 หลายเดือนก่อน

    Man, this is just pure masterpiece

  • @TheClanFollows
    @TheClanFollows ปีที่แล้ว

    Today I watched your video for the first time... I understood maybe 12% of it. Hopefully, next time I watch I'll retain more

  • @Spectacular_Monk
    @Spectacular_Monk ปีที่แล้ว

    Really nice and simple explanations. I revised the concepts I learnt before 2-3 months by watching this video

  • @yuurishibuya4797
    @yuurishibuya4797 ปีที่แล้ว

    Yet an another attempt was made to clear the mysterious design patterns. 😅
    Good video.
    I was talking about this yesterday with my colleague. You forgot the most important one, the state machines. Then again, if you are not from embedded world, the state machine pattern aren’t that often used.

  • @brahimboughanam1662
    @brahimboughanam1662 ปีที่แล้ว

    best explanation of design patterns
    thank you

  • @Gawie
    @Gawie ปีที่แล้ว

    This is a good video. I want to distribute it throughout our company, however if at all possible, can you create 1 using C# instead?

    • @Gawie
      @Gawie ปีที่แล้ว

      @@ghost_mall You're not wrong, but not all developers are equal, hence the request for something in C#

  • @pl5778
    @pl5778 ปีที่แล้ว

    Awesome video using real day to day example that anyone can understand. I especially like the burger analogy.

  • @mdanny42
    @mdanny42 ปีที่แล้ว

    “**presents incompatible screw/hole metaphor**, or maybe an example that you’re more familiar with…” - Brilliant 😂 Subscribed for the funny yet educative value, keep it up 👍🏼

  • @tempregex8520
    @tempregex8520 ปีที่แล้ว

    Insanely awesome video neetcode!

  • @MRxPoundcakes
    @MRxPoundcakes ปีที่แล้ว

    This was great, subscribed!

  • @marcelk6514
    @marcelk6514 ปีที่แล้ว +10

    I think you should really have a good reason to use a pattern. The worst thing is having the wrong abstraction for the job. Too many times, people learn these pattern and just start randomly applying them everywhere. And before you know, everything is a abstract factory adapter strategy

  • @velimirchakhnovski2380
    @velimirchakhnovski2380 ปีที่แล้ว +9

    If the iterator pattern is implemented directly on the data structure like in this video, you can only iterate it once.
    Instead, ___iter___ should return a new ListIterator, and this ListIterator should have a ___next___ method

  • @shubhankar915
    @shubhankar915 ปีที่แล้ว +2

    There is a difference between pubsub and observer pattern. In pubsub, the publisher doesn't know who the subscribers are but in observer pattern, list of observers are known to the observant

    • @whossname4399
      @whossname4399 ปีที่แล้ว

      The more important distinction is that in pubsub subscribers aren't guaranteed to receive the message, so you need to handle what happens if the message isn't received

    • @Wouldntyouliketoknow2
      @Wouldntyouliketoknow2 ปีที่แล้ว

      Yet with a transactional outbox approach, subscribers are guaranteed to "eventually" recieve the message at least once so it becomes about ensuring idempotence.

    • @whossname4399
      @whossname4399 ปีที่แล้ว

      @@Wouldntyouliketoknow2 my experience with pubsub is with systems that send a few messages a minute, so my approach has generally been either ignore the missed messages if they don't matter anymore, or include a sequence number to detect missed messages and a mechanism for the subscriber to query any messages that it misses.

  • @learnwithme3364
    @learnwithme3364 ปีที่แล้ว

    Im learning MVVP with C# wpf. That's awesome

  • @9844manish
    @9844manish 6 หลายเดือนก่อน

    I like the way you explain things with examples, Your are dope bro, also use of funny and meme btw videos keeps users active :). Love from India 💌

  • @emirhanbilgic2475
    @emirhanbilgic2475 ปีที่แล้ว +1

    amazing video, a neetcode class. thank you

  • @MichelAlbert
    @MichelAlbert ปีที่แล้ว

    This is a nice summary but it is missing a crucial detail for design patterns: WHY do you use each one? Or phrased differently: which problem does each one solve? Knowing that will make it a lot easier to know when to apply which pattern. Or even recognise that there is a more language idiomatic solution available

  • @LOLorMrLOL
    @LOLorMrLOL ปีที่แล้ว

    What a great and simple to understand video! Thank you

  • @xydez
    @xydez ปีที่แล้ว

    Ngl this explanation was incredible

  • @haodeng9639
    @haodeng9639 ปีที่แล้ว

    Not only every developer, but also everyone on the earth should know!!!

  • @Brlitzkreig
    @Brlitzkreig ปีที่แล้ว

    Wow, you're an incredible teacher

  • @vivekpujaravp
    @vivekpujaravp ปีที่แล้ว

    This is fantastic. Please keep making more videos.

  • @darshanrathod9572
    @darshanrathod9572 ปีที่แล้ว

    ex. of adapter was so good for understanding.

    • @yurysudak
      @yurysudak 7 หลายเดือนก่อน

      Yeah, even music added :)

  • @bladerboi87
    @bladerboi87 7 หลายเดือนก่อน

    🎯 Key points for quick navigation:
    🍔 Factory Pattern: Create objects without specifying the exact class
    🏗️ Builder Pattern: Create objects step-by-step
    🔌 Adapter Pattern: Make incompatible interfaces work together
    📢 Observer Pattern (Pub/Sub): Allow objects to subscribe to updates from other objects
    🔁 Iterator Pattern: Access elements of an object sequentially
    🧭 Strategy Pattern: Change an object's behavior at runtime
    Facade Pattern: Provide a simple interface to a complex system
    ♻️ Strategy Pattern: Change an object's behavior at runtime by passing strategies
    Adapter Pattern: Make incompatible objects work together (like an adapter for different plugs)
    Facade Pattern: Provide a simple interface to a complex system (hide complexity behind a simpler facade)
    Made with HARPA AI

  • @TheStan4431
    @TheStan4431 ปีที่แล้ว

    That was very nice! It remembers me some ways to do things in OOP :D
    I'll definitely recommand this vidéo to my students!!

  • @goodwish1543
    @goodwish1543 ปีที่แล้ว

    This is valuable . Are there more popular Design patterns not in this list ?

  • @이수연-p1f9n
    @이수연-p1f9n ปีที่แล้ว

    Very useful, thanks!

  • @taylorperkins5279
    @taylorperkins5279 ปีที่แล้ว

    Love this! Brilliant

  • @happyhawe2783
    @happyhawe2783 ปีที่แล้ว

    i think good idea is write this 8 patterns in language u work look at it when u start the problem and choose the best. This is the fastest way to larne it in my opinion :o

  • @KevinNaughtonJr
    @KevinNaughtonJr ปีที่แล้ว

    builder pattern is goated

  • @chikenmacnugget
    @chikenmacnugget ปีที่แล้ว +2

    Me: open video about patterns
    TH-camr: js was a misstake
    Me: close the video and open book about patterns

  • @suryarajendran7736
    @suryarajendran7736 ปีที่แล้ว

    Please make a video for other design patterns too like command pattern

  • @rockenOne
    @rockenOne ปีที่แล้ว

    Interested where you get the idea JavaScript frameworks are going out of style, is this something you want to correct?

  • @minh-tamvo4608
    @minh-tamvo4608 ปีที่แล้ว

    great video, I learned ALOT

  • @Mickymauserius
    @Mickymauserius ปีที่แล้ว

    If you write a class, which only can instantiate one object and raises an error if you try to instantiate a second object - is this still a singleton?

  • @jordiyaputra8359
    @jordiyaputra8359 ปีที่แล้ว

    Yes, I've made sure I subscribed just now :)

  • @ayzchen1
    @ayzchen1 ปีที่แล้ว

    Thank you very much for this awesome video! Could you please do a video on dependency injection design pattern? Thank you!

  • @gjcardonam
    @gjcardonam ปีที่แล้ว

    Of course I will subscribe. What a better thing do I have to do? Thanks

  • @hlubradio2318
    @hlubradio2318 8 หลายเดือนก่อน

    Very interesting never encountered design systems before

  • @ice641
    @ice641 ปีที่แล้ว

    You earned a subscription

  • @davidbarrar5968
    @davidbarrar5968 11 หลายเดือนก่อน

    Can you elaborate more why you used the Builder Pattern a lot of Protocol Buffers? Thanks

  • @KimboH55
    @KimboH55 ปีที่แล้ว

    Hi from a patterns newbie. How do you print or display the result from the builder pattern? This is an excellent series of explanations. Thanks

  • @smiley2827
    @smiley2827 ปีที่แล้ว

    This video is so good 🙏

  • @Mikenight120
    @Mikenight120 ปีที่แล้ว

    Awesome content🦾 Just subscribed.

  • @emilianosantos2081
    @emilianosantos2081 ปีที่แล้ว

    Amazing content!!!! 😍

  • @LittlesProductReviews1
    @LittlesProductReviews1 ปีที่แล้ว

    2:20 I knew you could use the backslash to extend if statements more than one physical lines but I did not know you could use it in this way too.

  • @saxa1165
    @saxa1165 ปีที่แล้ว

    Informative and entertaining! :)

  • @acupsf
    @acupsf ปีที่แล้ว

    Great talk!

  • @Slacquerr
    @Slacquerr ปีที่แล้ว

    Clear. Concise.

  • @vinitsharma6630
    @vinitsharma6630 ปีที่แล้ว

    Is from abc import ABC , abstractmethod defined by neetCode or its actual library used to implement abstract classes in python?