概述
Singleton模式要求一个类有且仅有一个实例,并且提供了一个全局的访问点。这就提出了一个问题:如何绕过常规的构造器,提供一种机制来保证一个类只有一个实例?客户程序在调用某一个类时,它是不会考虑这个类是否只能有一个实例等问题的,所以,这应该是类设计者的责任,而不是类使用者的责任。
从另一个角度来说,Singleton模式其实也是一种职责型模式。因为我们创建了一个对象,这个对象扮演了独一无二的角色,在这个单独的对象实例中,它集中了它所属类的所有权力,同时它也肩负了行使这种权力的职责!
意图
保证一个类仅有一个实例,并提供一个访问它的全局访问点。
模型图
逻辑模型图:
物理模型图:
生活中的例子
美国总统的职位是Singleton,美国宪法规定了总统的选举,任期以及继任的顺序。这样,在任何时刻只能由一个现任的总统。无论现任总统的身份为何,其头衔"美利坚合众国总统"是访问这个职位的人的一个全局的访问点。
以上内容来自 点击打开链接
单例模式分为懒汉式和饿汉式
懒汉式:
public class SingleMode {
private static SingleMode mThisMode;
SingleMode() {
}
public static SingleMode getInstance() {// 懒汉式单例类
if (mThisMode == null)
mThisMode = new SingleMode();
return mThisMode;
}
}
饿汉式:
public class SingleMode {
private static SingleMode mThisMode;
// 已经自行实例化,饿汉
private static final SingleMode mThisMode2 = new SingleMode();
private SingleMode() {
}
public static SingleMode getInstance2() {// 饿汉式单例类
return mThisMode2;
}
}
由于单例模式涉及到了同步问题,我们应该这么干
public class Singleton {
private static Singleton instance = null;
private Singleton() {
// dosomething
}
public static Singleton getInstance() {
if (instance == null) {
synchronized (Singleton.class) {
if (null == instance) {
instance = new Singleton();
}
}
}
return instance;
}
}