Welcome to my site

Post statistics

Design Pattern I: Singleton

In this first episode of PHP design patterns, we will be looking at the Singleton. The Singleton is available in most, if not all, OO languages. The purpose of the Singleton is to only ever have 1 instance of a class available which supplies the rest of the application with consistent data. I would like to point out that my version of a Singleton may differ slightly from other peoples; design patterns are not exact nor are they set in stone.

Due to its consistency, the Singleton design pattern is great for classes such as user information, site details, or site settings whereby it is needed all over the system, not just in a single place.

To start we need to define our class, and create the static property which will hold the class instance, and create the repository for all our data. This static variable will remain the same over the course of the runtime of the script, allowing us to access our consistent data.

<?php
class Singleton
{
    private static $_Singleton;
    private $_repository = array();
 
    private function __construct(){}
}

Here we have defined our class, created the static variable, and defined the constructor method. Several things may hit you when you view this snippet, first being that we have an underscore after the dollar sign; this is to show that it is a class attribute. Also, we have made out constructor private and given it no logic. This is because we do not want to create an instances of the class, we instead want to return an instance of the class. We do this by adding another function called getSingleton() which will set the class and return it. Let’s see what that will look like.

<?php
class Singleton
{
    private static $_Singleton;
    private $_repository = array();
 
    private function __construct(){}
 
    public function getSingleton()
    {
        if (is_null(self::$_Singleton))
        {
            self::$_Singleton = new Singleton();
        }
 
        return self::$_Singleton;
    }
}

We first test to see whether or not we have created an instance of the Singleton before, if we haven’t then we create it, and then return the instance. We use self::$_Singleton because we are dealing with a static method. The only thing left to do now is to set the data and allow our script to obtain that data.

<?php
class Singleton
{
    private static $_Singleton;
    private $_repository = array('Dog' => 'Woof!',
                                 'Cat' => 'Meow!',
                                 'Cow' => 'Mooo!');
 
    private function __construct(){}
 
    public function getSingleton()
    {
        if (is_null(self::$_Singleton))
        {
            self::$_Singleton = new Singleton();
        }
 
        return self::$_Singleton;
    }
 
    public function retrieve($index)
    {
        if (array_key_exists($index, $this -> _repository))
        {
            return $this -> _repository[$index];
        }
    }
}

And there we have it, our lovely Singleton design pattern. I have decided for this example for simplicity sake to set some values to play with, in a live application you might query a database or get the values from a file out of the document root. Within the retrieve() function we first make sure that the index exists within our repository; if it does then it returns the value. Since the Singleton class should contain set values and be called from other classes, the array index should always exist—you might even want to put some error handling on the function to log anything that it can’t find. Lets look at am example of this in action.

<?php
class Singleton
{
    private static $_Singleton;
    private $_repository = array('Dog' => 'Woof!',
                                 'Cat' => 'Meow!',
                                 'Cow' => 'Mooo!');
 
    private function __construct(){}
 
    public function getSingleton()
    {
        if (is_null(self::$_Singleton))
        {
            self::$_Singleton = new Singleton();
        }
 
        return self::$_Singleton;
    }
 
    public function retrieve($index)
    {
        if (array_key_exists($index, $this -> _repository))
        {
            return $this -> _repository[$index];
        }
    }
 
    public function changeCat()
    {
        $this -> _repository['Cat'] = 'Baaa!';
    }
}
 
$eg1 = Singleton::getSingleton();
echo 'Singlton 1: ' . $eg1 -> retrieve('Cat') . '<br />';
 
$eg1 -> changeCat();
 
$eg2 = Singleton::getSingleton();
echo 'Singlton 1: ' . $eg1 -> retrieve('Cat') . '<br />';
echo 'Singlton 2: ' . $eg2 -> retrieve('Cat');

This should hopefully produce the following:

Singlton 1: Meow!
Singlton 1: Baaa!
Singlton 2: Baaa!

In real life you wouldn’t change the values of the data stored in a singleton (as that would then become more a Registry pattern, which I will look at next), however, this is just to show you that the data is the same for all instances created.

Date posted June 26th, 2007
Comments Disabled
Categories PHP
Author Christopher Hill

I'm Christopher. A twenty-something graduate, star gazer, aspiring triathlete, vegetarian, reader and writer, cinemaniac and lover of life in general

From the journal

From the deep

Obligatory links

Create simple UML diagrams on-the-fly

yUML is an online tool for creating and publishing simple UML diagrams. It’s makes it really easy for you to: Embed UML diagrams in blogs, emails and wikis, Post UML diagrams in forums and blog comments, Use directly within your web based bug tracking tool and Copy and paste UML diagrams into MS Word documents and Powerpoint presentations.

Javascript Tidy

One thing I often need to do is to tidy javascript from it’s packed state. Often to fix the developers bugs, add new features or to modify it slightly. I give you, the Javascript Tidy, a tool I couldn’t live without.

jQuery Slider plugin (Safari style)

A pretty awesome slider. Haven’t tried it out yet but the new version seems pretty easy to skin, so you can style it however-the-hell you want (note: click the ‘jQuery Slider update’ link).

MySQL Format Date

MySQL Format Date helps you format your dates using the MySQL DATE_FORMAT function. Just select a common date format and then change it to your suit your needs. The MySQL DATE_FORMAT code will be generated at the bottom of the page which you can then copy into your query.

The future of wireframes?

I have a love hate relationship with wireframes. In the last 10 years they’ve been a part of every web project I’ve worked on. There have been times when I can’t imagine how we would have solved a particular problem without them. Yet there are also times when I’ve been completely exasperated at the amount of time and energy they’ve consumed, seemingly to very little reward.

So you need a typeface?

A pretty humorous look into how you could choose your typeface for your next project.

New global visual language for BBC

We decided to embark on an ambitious project, called Global Visual Language 2.0, with the aim of unifying the visual and interaction design of bbc.co.uk and the mobile website.

jQuery plugin: Nivo Slider

A really cool image slider than has some unique transitional effects without using Flash.

MooTools plugin: DatePicker

jQuery has the best functioning plugins. MooTools has the best looking plugins. Whenever I want to add in a datepicker I always find this and think: “Oooh. Pretty. Do want.”. Then realise it’s MooTools only. Real shame.

jQuery plugin: Sparklines

I know, I know. This plugin has been around for, what seems like, years. But I thought I would give it a little bit of a spotlight. And yes, so I can easily find it again.

jQuery plugin: asmSelect

asmSelect is a jQuery plugin providing progressive enhancement to select multiple form elements. It provides a simpler alternative with several advantages. This new version includes several bug fixes and enhancements.

How coupon codes can lead to lost revenue

In this post we’ll be looking at how coupon codes (used synonymously here with promo and discount codes) can cause retailers to lose revenue. I’ll share some (hopefully) interesting trends that I’m seeing with a client I work with, and hopefully start a discussion with how to turn lost revenue into gained revenue.

A good browser should be able to reproduce itself

This is an interesting project which aimes to completely reproduce the visual aspect of Safari in pure HTML+CSS with zero images. There are a few caveats at the moment, such as no refresh button, but they say they are working on it. Once again this really shows the power that HTML5 and CSS3 brings to the Web.

jQuery plugin: gameQuery

gameQuery is a jQuery plug-in to help make javascript game development easier by adding some simple game-related classes. It’s still in an early stage of development and may change a lot in future versions.

CSS/Javascript Word Clock

A lit­tle ex­per­i­ment I built: a word clock using CSS3 trans­forms and a lit­tle Javascript to run the ac­tu­al clock. Use­ful? Maybe not. Fun? Def­i­nite­ly.

CSS Border Radius Web Page

It’s one of those things that makes you think “Doh! I should have made that agaes ago”. A simple Web page that allows you to simply get the CSS for the exact border radius you want.

The main thing is not to install Flash

A security expert who has won the Pwn2Own contest for 2 years running said, basically, that Flash is insecure. Well, we all knew that which is why we add Flashblock and the like. Right?

Pure CSS3 Bokeh effect

One of the best apps made using CSS3, that’s for sure. A few more options would be nice, such as changing colours of the circles and being able to place them manually.

EZ-CSS: An easy to use, lightweight, CSS framework

It is light (1kb), flexible, browser-friendly and easy to use! ez-css is a different kind of CSS framework. Authors are not bound to a “grid”. Plus, columns and gutters can be of any width.

jQuery plugin: Quicksand

I love Mac apps, especially for their attention to detail. CoreAnimation makes it so easy to create useful and eye-pleasing effects. Quicksand aims at providing a similar experience for users on the web.