Should I implement IDisposable on a singleton?

前端 未结 3 895
别那么骄傲
别那么骄傲 2021-01-13 22:19

I have a windows service, which contains a singleton which in turn uses some loggers, message queue listeners and so on. Those classes implements IDisposable. S

相关标签:
3条回答
  • 2021-01-13 22:52

    I'd rather not implement IDisposable on singleton: IDisposable provokes developer to Dispose the (single) instance:

      using(var temp = Temp.Instance) {
        ...
      }
    

    which leads to (possible) crash in some other part of the application (since the single Temp instance has been disposed):

      Temp.Instance.SomeFucntion(); // <- possible fail, since Temp.Instanceis disposed
    

    In some rare case if you have to release some resouces aquired, I'd use ProcessExit event

    public class Temp {
       private static readonly Lazy<Temp> instance = new Lazy<Temp>(() => new Temp());
    
       private void OnProcessExit(Object sender, EventArgs e) {
         // Release native resource if required:
         // some resources e.g. files will be closed automatically,
         // but some e.g. transactions should be closed (commit/rollback) manually
         try {  
           ...
         }
         finally { 
           AppDomain.CurrentDomain.ProcessExit -= OnProcessExit;
         }   
       }
    
       private Temp() {
         // create IDisposable objects which use native resources
    
         // If you have to release some resouces on exit
         AppDomain.CurrentDomain.ProcessExit += OnProcessExit;
       }
    
       public static Temp Instance {
         get {
           return instance.Value;
         }
       }
    } 
    
    0 讨论(0)
  • 2021-01-13 23:05

    If a type will be returned from a factory that will sometimes need to be cleaned up when the caller is done with them, the type should implement IDisposable. If a particular factory returns a shared singleton object that doesn't actually need any resources, the object returned by the factory should have a Dispose method which silently does nothing. If the factory needs to provide access to a shared singleton resources (e.g. an immutable bitmap stored in a GDI object), it should return a wrapper which will notify the factory when it its Dispose method is called; the factory can then maintain a reference count of wrapper objects and clean up the resource once it knows that no more wrappers will be created and all existing wrappers have been disposed.

    0 讨论(0)
  • 2021-01-13 23:15

    No; Singleton shouldn't implement IDisposable. What if someone disposes the instance prematurely when others are in need of that?

    Also note that implementing IDisposable will not help you when your service is crashed/stopped. You'll have to dispose it manually! but you can't find right time to do it.

    0 讨论(0)
提交回复
热议问题