单例模式:确保一个类只有一个实例,并提供一个全局访问点
有时候我们需要一个类只能有一个实例,例如线程池,注册表的对象,日志对象。事实上,这些对象只能有一个实例,如果制造出多个实例就会导致许多问题。例如:程序的异常,资源使用过量或者结果不一致。
下面我们就实现一个只能产生一个对象的类。
package com.wdf.singleton;
public class Singleton {
private static Singleton uniqueInstance;//静态变量记录Singleton类的唯一实例
private Singleton(){}//把构造器定义为私有的,只有类内才可以调用构造器
/*
* 用getInstance()方法实例化对象,返回这个实例
* */
public static Singleton getInstance(){
if(uniqueInstance==null){
uniqueInstance=new Singleton();
}
return uniqueInstance;
}
}
处理多线程问题
1.如果getInstace()的性能对应用程序不是很关键,在getInstance前面加上synchronized
package com.wdf.singleton;
/*
* 单例模式
* */
public class Singleton {
private static Singleton uniqueInstance;//静态变量记录Singleton类的唯一实例
private Singleton(){}//把构造器定义为私有的,只有类内才可以调用构造器
/*
* 用getInstance()方法实例化对象,返回这个实例
* */
public static synchronized Singleton getInstance(){
if(uniqueInstance==null){
uniqueInstance=new Singleton();
}
return uniqueInstance;
}
}
2.使用“急切”创建实例,而不用延迟实例化的做法
public class Singleton {
private static Singleton uniqueInstance=new Singleton();//静态变量记录Singleton类的唯一实例
private Singleton(){}//把构造器定义为私有的,只有类内才可以调用构造器
/*
* 用getInstance()方法实例化对象,返回这个实例
* */
public static Singleton getInstance(){
return uniqueInstance;
}
}
3.使用“双重检查加锁”,在getInstance里面减少同步
public class Singleton {
private static Singleton uniqueInstance=new Singleton();//静态变量记录Singleton类的唯一实例
private Singleton(){}//把构造器定义为私有的,只有类内才可以调用构造器
/*
* 用getInstance()方法实例化对象,返回这个实例
* */
public static Singleton getInstance(){
if(uniqueInstance==null){
synchronized(Singleton.class){
uniqueInstance=new Singleton();
}
}
return uniqueInstance;
}
}