Singleton Pattern Demo

 

package SingletonPatternDemo; public class ReportHeader { private static volatile ReportHeader instance; private String header; // Private constructor private ReportHeader() { // Code to initialize the header this.header = "ABC Programming Company\nSan Antonio Office\n210-837-1234\n\n"; } // Public method to get instance public static ReportHeader getInstance() { if (instance == null) { synchronized (ReportHeader.class) { if (instance == null) { instance = new ReportHeader(); } } } return instance; } public String getHeader() { return this.header; } // New printHeader method public void printHeader() { System.out.println(this.header); } }
package SingletonPatternDemo; public class SingletonDemo { public static void main(String[] args) { ReportHeader reportHeader = ReportHeader.getInstance(); reportHeader.printHeader(); // Using the new printHeader method // Write report } }

Let's consider a Report Header Singleton class that provides a consistent header for all reports generated by the system. The Singleton ensures that we only create one instance of the header for efficiency and consistency.

In the above example, ReportHeader is our Singleton class. It contains a private header string that holds the report header. The getInstance method provides access to the Singleton instance.

The ReportWriter class uses the Singleton to retrieve the report header. When the ReportWriter is run, it will print the report header to the console.

This example ensures there is always a single, consistent header used across all reports in the application.