单例模式的特点为:
*单例类只有一个实例。
*单例类必须自己创建自己的唯一实例。
*单例类必须给所有其他对象提供这一实例。
饿汉式单例类:
而饿汉式单例类则在java语言中是最为简单的单例类,这是一个描述饿汉式单例类的类图的实现。
此类图中,此类已经将自己实例化。
源码为:
package singleton;
public class EagerSingleton {
private static EagerSingleton instance=new EagerSingleton();
/**
* 私有的默认构造子
* @return
*/
public EagerSingleton(){}
/**
* 静态工厂方法
* @return
*/
public static EagerSingleton getInstance(){
return instance;
}
}
可以看出,在这个类被加载时,静态变量instance已经实例化,此时类的私有构造方法就会被调用,这时,
单例类的唯一实例对象就被创建出来。
在单例类中一个最重要的特点就是类的构造方法是私有的,因此,该类无法被继承。
懒汉式单例类:
与饿汉式单例类相同之处是类的构造方法是私有的,与饿汉式单例类不同的是,懒汉式单例类,在第一次被引用时将自己实例化,
如下图所示,uml类图中给出了一个典型的懒汉式单例类实现。
懒汉式的源码为:
package singleton;
public class LazySingleton {
private static LazySingleton instance=null;
/**
* 私有的构造函数,保证外界无法实例化
*/
private LazySingleton(){}
/**
* 静态工厂方法,返回此类的唯一实例
*/
public synchronized static LazySingleton getInstance(){
if(instance==null){
instance=new LazySingleton();
}
return instance;
}
}
饿汉式单例类和懒汉式单例类,饿汉式单例类在自己被加载时就将自己实例化,即便加载器是静态的,
在饿汉式单例类被加载时仍会将自己实例化,单从资源利用效率角度来讲,这个比懒汉式单例类稍差些。
但从速度和反应时间角度来讲,则比懒汉式单例类稍好些,然而,懒汉式单例类在实例化时,必须要处理好
在多个线程同时首次引用此类时的访问限制问题,特别是当单例类作为资源控制器在实例化必然涉及资源初始化,
而资源初始化可能会很费时间,这意味着出现多线程同时引用此类的几率变得较大。
原文:http://blog.csdn.net/u012734441/article/details/44236221