单例模式是创建模式中普遍采用的一种。使用单例模式可以确保某个类只会有一个实例被创建。单例模式是通过下面的思想来保证的:不让类以外的任何事物创建对象的实例 。通常来讲,单例可以缩减内存 的需求。实现方式也有很多种。单例模式分三种:懒汉式单例、饿汉式单例、登记式单例三种。
单例模式主要有以下特点:
1、单例类只能有一个实例。
2、单例类必须为自己创建自己的唯一实例。
3、单例类必须给所有其他对象提供这一实例。
一. 懒汉式
在类被加载的时候,单例模式的唯一一个实例已经被加载.
class Singleton { private static Singleton instance=null; private Singleton(){} //构造函数必须私有化 static Singleton getInstance() {//这个方法一定要是静态的,保证类可以直接调用 if(instance==null) //如果该唯一实例不存在,就创建一个 instance=new Singleton(); return instance; } } }
二.饿汉式
在类加载的时候不创建单例实例。只有在第一次请求实例的时候的时候创建,并且只在第一次创建后,以后不再创建该类的实例。
class Singleton { private static finalSingleton instance=new Singleton(); private Singleton(){} static Singleton getInstance() { return instance; } }
三.登记式
这个单例实际上维护的是一组单例类的实例,将这些实例存放在一个Map(登记薄)中,对于没有登记的,则先登记,而后返回,对于已经登记过的实例,则从工厂直接返回。
class RegSingleton { private static Map registry = new HashMap(); //登记簿,用来存放所有登记的实例 // 在类加载的时候添加一个实例到登记薄 static { RegSingleton regSingleton = new RegSingleton(); registry.put(regSingleton.getClass().getName(),regSingleton); } protected RegSingleton() {}//受保护的默认构造方法 /** * 静态工厂方法,返回指定登记对象的唯一实例; * 对于已登记的直接取出返回,对于还未登记的,先登记,然后取出返回 * @param name * @return RegSingleton */ public static RegSingleton getInstance(String name) { if (name == null) { name = "RegSingleton"; } if (registry.get(name) == null) { try { registry.put(name,(RegSingleton) Class.forName(name).newInstance()); } catch (InstantiationException e1) { e1.printStackTrace(); } catch (IllegalAccessException e2) { e2.printStackTrace(); } catch (ClassNotFoundException e3) { e3.printStackTrace(); } } return (RegSingleton) registry.get(name); } }