C# Design Pattern: Singleton
In the Singleton Pattern we have at any given instance a single instance of the Singleton Class active. All instantiation of the Singleton Class references the same instance of the Class. The pattern also provides a global point of access to the sole instance of the class.
Class Diagram
Sequence Diagram
Implementation
Steps for implementing the Singleton Pattern:
Step1:
Create a project of type Console Application. Name it SingletonTest.
Step2:
Add a Class File named Singleton and add the following code
/// /// Summary description for Singleton. /// public class Singleton { //Fields private static Singleton instance; /// /// Standard default Constructor /// protected Singleton() {} /// /// Static method for creating the single instance /// of the Constructor /// /// public static Singleton Instance() { // initialize if not already done if( instance == null ) instance = new Singleton(); // return the initialized instance of the Singleton Class return instance; } } |
Step 3:
Create a Client class that would access the Singleton Class as follows :
/// /// Summary description for Client. /// class Client { /// /// The main entry point for the application. /// [STAThread] static void Main(string[] args) { // Constructor is protected -- cannot use new Singleton s1 = Singleton.Instance(); Singleton s2 = Singleton.Instance(); if( s1 == s2 ) Console.WriteLine( "The same instance" ); Console.ReadLine(); } } |
Step 4:
Run the Application it would display the following output:
Conclusion
Thus we have implemented the Singleton Design Pattern using the .Net framework.Like any Concepts/Theory Singleton Pattern also has its pros and cons.
Benefits of Singleton Pattern:
1. Instance control: Singleton prevents other objects from instantiating their own copies of the Singleton object, ensuring that all objects access the single instance.
2. Flexibility: Because the class controls the instantiation process, the class has the flexibility to change the instantiation process.
Drawbacks of Singleton Pattern:
1. Overhead. Although the amount is minuscule, there is some overhead involved in checking whether an instance of the class already exists every time an object requests a reference. This problem can be overcome by using static initialization
2. Possible development confusion. When using a singleton object (especially one defined in a class library), developers must remember that they cannot use the new keyword to instantiate the object. Because application developers may not have access to the library source code, they may be surprised to find that they cannot instantiate this class directly.
3. Object lifetime. Singleton does not address the issue of deleting the single object. In languages that provide memory management (for example, languages based on the .NET Framework), only the Singleton class could cause the instance to be deallocated because it holds a private reference to the instance. In languages, such as C++, other classes could delete the object instance, but doing so would lead to a dangling reference inside the Singleton class.
0 Comments:
Post a Comment
<< Home