Singleton Pattern - Design Patterns

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

КОМЕНТАРІ • 104

  • @KallyanBRoy
    @KallyanBRoy 4 роки тому +27

    Most of the NPM modules (major ones) uses this pattern, e.g: Mongoose. This pattern is one of the best if anyone is creating a library or something like that as you might need to output some debug information for the module. Great video thanks a lot....BTW thanks for changing your uniform

  • @fabriziotofanelli
    @fabriziotofanelli 5 років тому +35

    its kind weird to see this smooth explanation regarding this subject because, most of times, some teachers don't really grasp this concept and makes this even harder... great content man... keep it up =)

    • @WebDevSimplified
      @WebDevSimplified  5 років тому +11

      Thanks! I really appreciate it. I always put in extra time researching and working with any technology/topic before I record a video on it even if I already know it really well, since I want to make sure I understand all the intricate details so I know which parts are the important parts I need to explain in a way that makes sense.

    • @fabriziotofanelli
      @fabriziotofanelli 5 років тому +5

      @@WebDevSimplified And I really appreciate your efforts to bring us the best way to absorbe, sometimes, complex subjects and break them into tiny pieces easily to understand and digest.... hope to see much more great content from you =)

  • @omarabid3932
    @omarabid3932 3 роки тому +17

    Hi, The implementation looks good but In order to verify that the singleton implementation is working correctly you need to instantiate the FancyLogger twice, in your current implementation the constructor is called only once.

    • @Gabriel-V
      @Gabriel-V 2 роки тому +3

      Agreed. And the export is the class itself, because whenever you run new FancyLogger(), you will get back the same FancyLogger instance. and that is handled inside the class constructor itself. If you export the logger instance created, as shown in the video, the constructor doesn't need to be changed this way

    • @Matter743
      @Matter743 Місяць тому

      Better use typescript instead of js and make the constructor private

  • @julescsv7012
    @julescsv7012 3 роки тому +4

    Sometimes I wonder where I would be without you. 🙏🙏🙏

  • @nabiisakhanov3522
    @nabiisakhanov3522 4 роки тому +9

    Angular services are singleton by default, so I guess this pattern does have its niche

  • @thehardyboiz1
    @thehardyboiz1 5 років тому +6

    This was pretty useful, i hope that your channel grows a lot in the next few months, you totally deserve it :)

    • @WebDevSimplified
      @WebDevSimplified  5 років тому

      Thank you. My channel has already grown a lot the last few months. I can't imagine even more growth.

    • @davidfonseca698
      @davidfonseca698 4 роки тому

      And now your words became real. Just last week 20 thousands people subscribe to this channel!

  • @ardhiirfansyabani4921
    @ardhiirfansyabani4921 3 роки тому +4

    to the point and really understandable! love it! keep up those great contents!

  • @klauspetersen8593
    @klauspetersen8593 4 роки тому +4

    Why export an instance variable? Wouldn't it be the same if first and second file just call new, which would return the same instance and then move Object.freeze into the constructor? Thinking it would be a cleaner solution

    • @WaldoTheWombat
      @WaldoTheWombat 5 місяців тому

      Yeah I also didn't get that, Kyle already solved it in the constructor, so why can't the other files just the keep using the instantiating with the class?

  • @alejandroperezrivas2397
    @alejandroperezrivas2397 5 місяців тому

    damn this has to be one of the best explanations i had with this pattern.

  • @karthik-ex4dm
    @karthik-ex4dm 4 роки тому

    The only video I found on youtube with 10K+ views and 0 dislikes...
    For a long time, I was thinking guys at youtube randomly add dislikes to videos coz there are many good videos that got dislikes for no reason...

  • @user-se8hw9kn3m
    @user-se8hw9kn3m Місяць тому

    Thanks kyle. Very well explained.

  • @samislam2746
    @samislam2746 3 роки тому

    *If somebody knows please help*, What will happen when you write:
    class X {
    constructor(){
    X.instance = 8; // Here
    }
    }
    1- What does X.instance mean? It's mentioned in the video nearly at 6:00
    2- Where the X.instance is going to be?
    3- What is the difference approach and using a static property?

    • @tyafizi
      @tyafizi 3 роки тому +2

      1. It's mean that you set static property called 'instance' for your class X.
      2. In the class like any other static fields.
      3. Difference is that if you use this approach method you can't define an instance property without creating an instance of this class.
      class MyClass {
      constructor() {
      if (!MyClass.instance) {
      MyClass.instance = this;
      }
      return MyClass.instance;
      }
      field = 42;
      }
      console.log(MyClass.instance); //undefined
      const myClass = new MyClass();
      console.log(MyClass.instance); //MyClass {field:42} (Or in your case 8)
      So all next instances will be known that you've already created some instance and instead of returning new X they will return that instance
      const newClass = new MyClass();
      console.log(myClass === newClass); //true

  • @tlev615
    @tlev615 3 роки тому +2

    Great explanation, and thanks for the video, just have 1 question, is it really necessary to do this manipulations inside constructor, if we import instance of logger it will be same instance for any file because of modules that are singletones anyway? Just wondering why we really need that checks here?

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

      Same question!

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

      If you work in a team, you want other people to use it correctly. Let's say it's the company directive to get the log count.
      If a person would by accident instantiate FancyLogger, they'd make a silent error. People will get the wrong log count and won't know that. If you make a class, you should make sure that others will use it correctly.

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

    Nice explenation but... All the design patterns should be presented in TypeScript. The key words like private, public, static, protected are crucial in my opinion. On the other hand, Everyone who has the TS knowledge should handle to add TS to your's code :) Thank You!

  • @penggao2615
    @penggao2615 2 роки тому +3

    Hi Kyle, thanks for the video. I have a question regarding to this singleton pattern: what's the difference between using an instance 'logger' and using a 'static' class attribute in the class 'FancyLogger' to record the logs ?

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

      Don't Know about JS but as for Java a class cannot be static , only its members can be static. A static member can be access by all instances of that class.

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

      Here is a sample code for Java Singleton Class , which may clear the difference between Singleton and Static Member

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

      public class Singleton {
      private static Singleton instance;
      private int value;
      private Singleton(int value) {
      this.value = value;
      }
      public static Singleton getInstance(int value) {
      if (instance == null) {
      instance = new Singleton(value);
      }
      return instance;
      }
      public int getValue() {
      return value;
      }
      }

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

    Such a good example!! Thank you!

  • @vinayyadav-qr7rb
    @vinayyadav-qr7rb 4 роки тому +2

    thank'u

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

    Very well explained. Thank you 🙏🏾

  • @Carl-yu6uw
    @Carl-yu6uw 4 роки тому

    Nice explanation, and use case, cheers. Do such singleton running on client side js commonly then persist their log array to db to allow after the fact debugging from one central place?

  • @ButtKraken01
    @ButtKraken01 3 роки тому

    Thanks for such a great explanation!

  • @rahimco-su3sc
    @rahimco-su3sc Рік тому

    thanks a lot for your efforts , i really appreciate that

  • @Colstonewall
    @Colstonewall 5 років тому +4

    I knew there was something I liked about You! Love the shirt. Any Zeppelin fan is a friend of mine. I'll shutup and sub, now.

    • @WebDevSimplified
      @WebDevSimplified  5 років тому

      Thanks! Zeppelin is an incredible band and always enjoyable to listen to.

  • @WaldoTheWombat
    @WaldoTheWombat 5 місяців тому

    But fi you already modified the constructor to always return the first instance that was ever created, then why can't you just keep exporting the class instead of that object like you did in the first place?

  • @marcosantonioreyesmedina2364
    @marcosantonioreyesmedina2364 4 роки тому +6

    Hi, very good video. We have always seen the "Singleton" pattern applied to a DB Connection class, what do you think ... do you think it is correct to apply it in this case?

    • @nonnodacciaio704
      @nonnodacciaio704 2 роки тому +1

      Yeah, that way you only have one connection and it's easier to manage

    • @mycommentmyopinion
      @mycommentmyopinion 11 місяців тому +1

      Depends on the use case / how often you make calls to your db. Look into database connection pooling

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

    Love this explanation

  • @johnnyxp64
    @johnnyxp64 5 років тому +5

    my favorite pattern! :)

    • @WebDevSimplified
      @WebDevSimplified  5 років тому +2

      Nice. What makes it your favorite. For my the command pattern is one of my favorite.

    • @johnnyxp64
      @johnnyxp64 5 років тому +4

      @@WebDevSimplified is just that since i started coding with gwbasic back in the 90s there was no patterns like today and without any special reading when i was 10 and discovered i could share data info among different "screens" by using a common "module"(even in today's vb.net is still been used) that was so excited for me as a kid. so is my favorite just for nostalgia reasons 🤣🤣🤣

    • @WebDevSimplified
      @WebDevSimplified  5 років тому +2

      @@johnnyxp64 That makes a lot of sense. Nostalgia is pretty powerful. For me the command pattern just really opened up how powerful clean code and design patterns can be which was really exciting.

    • @johnnyxp64
      @johnnyxp64 5 років тому +2

      @@WebDevSimplified makes sense. is one of the pillars in OOP (command pattern) in my opinion and everything that uses encapsulation is helping the coder to focus on what matters and keeps indeed a clean and more readable code. 😎

  • @karthikkumaresan1091
    @karthikkumaresan1091 4 роки тому

    awesome videos!! Keep them coming

  • @Crazould
    @Crazould 4 роки тому

    your videos are awesome! thank you so much!!

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

    great explanation, thank you

  • @mohitbhatia1994h
    @mohitbhatia1994h 5 років тому

    The best explanation !

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

    Singleton adalah 1 instance object sifatnya shared reaource sehingga bisa di pakai oleh object lain

  • @jenstornell
    @jenstornell 3 роки тому

    Is it a good idea to use singleton to simplify plugin methods, something like field.setValue(34); Then it's like a namespaced function where the plugin maker does not need to add new instances of the class.

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

    Isn't a database just a singleton? Its a shared resource that can be used by many other processes for different purposes, instead of each of those processes having their own separate set of data. Am I wrong, or do people that don't like singletons not like databases either?

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

    Can we use this instead of FancyLogger inside the constructor of FancyLogger?

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

    Can we say that some parts of state managers like Redux use the Singleton Pattern?
    Just to make sure I understood the concept here...

  • @mahdiwebdevelopment2338
    @mahdiwebdevelopment2338 4 роки тому

    What is strategy pattern? Make a video on this. Thanks

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

    is there a video on Factory Design Pattern ?

  • @shivaganga9148
    @shivaganga9148 4 роки тому

    Could you do a video on repository pattern

  • @audiodrocher
    @audiodrocher 4 роки тому

    Ohshhhh, this is llifechanging. Thanks a lot.

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

    thanks

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

    O hooo 1K to Million sub
    😻

  • @AcousticBruce
    @AcousticBruce 3 роки тому

    I paused video and tried something first and then I finished your video and saw it was much different.. Does anyone know the pros and cons of my version?
    let L;
    class Logger { ... }
    if (!L) {
    L = new Logger();
    }
    module.exports = L;
    Is there something wrong with this version? I did this in Node and because Node caches all uses of require, I figured this was okay.

  • @Mobin92
    @Mobin92 5 років тому +66

    Singleton pattern is basically a glorified global variable. Change my mind. :^)

    • @WebDevSimplified
      @WebDevSimplified  5 років тому +10

      You are completely right. I generally avoid this pattern, but there are cases where it can be useful.

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

    Error: "To load an ES module, set "type": "module" in the package.json or use the .mjs extension."

    • @AbhishekKumar-vl3cb
      @AbhishekKumar-vl3cb Рік тому

      1). npm init (under folder singleton)
      2). Add .js (import logger from './FancyLogger.js')

  • @WaldoTheWombat
    @WaldoTheWombat 2 місяці тому

    Hi Kyle!

  • @mangotree9629
    @mangotree9629 5 років тому

    Nice explain by u

  • @hugofilipeseleiro
    @hugofilipeseleiro 4 роки тому

    Thank y

  • @JonesDTaylor
    @JonesDTaylor 5 років тому

    great job.

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

    You are so handsome and smart. Clear explanation, thanks!

  • @TheBatags
    @TheBatags 5 років тому

    Cool Shirt!

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

    Dope!

  • @juanyang838
    @juanyang838 5 років тому

    Are there any differences between singleton pattern and database?

    • @WebDevSimplified
      @WebDevSimplified  5 років тому

      The singleton design pattern and databases are two completely different things. A database is a place to store information in an efficient long term place while the singleton design pattern is just a way to structure code so that you only ever have one global version of an object.

    • @juanyang838
      @juanyang838 5 років тому

      ​@@WebDevSimplified Then using a database to store an objects is waste and misused? I'm having a plan to create a small database for re-merging every properties on the same column and sending them back to the each instances just like how singleton does.

    • @WebDevSimplified
      @WebDevSimplified  5 років тому

      @@juanyang838 I am not sure what you mean. A database is for permanent storage of things you need to access later. I do not really know what you are trying to do.

  • @___dh__dh__
    @___dh__dh__ 2 місяці тому

    Why no ;

  • @mahdiwebdevelopment2338
    @mahdiwebdevelopment2338 4 роки тому

    Just wow! these days i was just looking for how to share class modules with other user objects. Just wow!

  • @samms7922
    @samms7922 3 роки тому +3

    Now I know how mongoose works behind the scenes.

  • @zum4342
    @zum4342 3 роки тому +2

    holy shit 0 dislikes. imma dislike it ahahhaahah jk bro ur awesome

  • @pipertripp
    @pipertripp 4 роки тому

    Zeppelin, nice.

  • @aissa.bouguern
    @aissa.bouguern 3 роки тому

    We can also create a singleton via a factory function instead of doing it inside class constructor.
    That's much cleaner imo.

  • @augischadiegils.5109
    @augischadiegils.5109 3 роки тому

  • @awekeningbro1207
    @awekeningbro1207 Місяць тому

    This is not correct. Returning a value from a constructor is ignored and can lead to unexpected behavior.

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

    so redux is singleton 🥲

  • @ZikoMario
    @ZikoMario 3 роки тому

    You have got 0.1% dislikes on your video, that is insane.

  • @yiminzhou7935
    @yiminzhou7935 3 роки тому

    you are so handsome

  • @ahmedboutaraa8771
    @ahmedboutaraa8771 3 роки тому

    .....

  • @greydiamondplayz2078
    @greydiamondplayz2078 5 років тому

    Singleton is my last name

  • @seanzoso
    @seanzoso 4 роки тому

    Led Zeppelin

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

    Incident implementation. It should just be a module, not a class.

  • @Incognito-ig7ld
    @Incognito-ig7ld 2 роки тому

    thanks, good, but not professional))

  • @ManuelMontoyaRdz
    @ManuelMontoyaRdz 22 дні тому

    Another reason why OOP sucks.

  • @akhilm4867
    @akhilm4867 5 років тому

    Second comment