/**
* 实现singleton的第二种方法,共有成员是个静态工厂方法。
* (第一种方法中公有静态成员是个final域,即直接使用private static final Singleton INSTANCE = new Singleton();)
* @author 刘向峰
*
*/
public class Singleton {
private static final Singleton INSTANCE = new Singleton();
/**
* 享有特权的客户端可以借助 java.lang.reflect.AccessibleObject.setAccessible(array,flag); 通过反射机制调用私有构造 。
* 为了抵御这种攻击,可以修改构造器,当它被要求创建第二个实例的时候会抛出异常
*/
private Singleton() {
//避免不小心在类的内部调用构造器
throw new AssertionError();
}
public static Singleton getInstance() {
return INSTANCE;
}
public void leaveTheBuilding() {
}
}
/**
* Java 1.5以后。只需编写一个包含单个元素的枚举类型实现singleton。
* 无偿地提供了序列化机制,绝对防止多次实例化,即使是在面对复杂的序列化或者反射攻击的时候。
* 单元素的枚举类型已经成为实现singleton的最佳方法。
* @author 刘向峰
*
*/
public enum EnumSingleton {
INSTANCE;
public void leaveTheBuilding(){}
}
/**
* 单例模式的序列化
* @author 刘向峰
*
*/
public class SerializeSingleton implements Serializable {
//将所有实例域声明为瞬时的
transient private static final SerializeSingleton INSTANCE = new SerializeSingleton();
//提供一个readResolve方法,否则,每次反序列化一个序列化的实例时,都会创建一个新的实例
private Object readResolve(){
return INSTANCE;
}
private SerializeSingleton() {
throw new AssertionError();
}
public static SerializeSingleton getInstance() {
return INSTANCE;
}
public void leaveTheBuilding() {
}
}
用私有构造器或者枚举类型强化singleton属性——Effective Java 读书笔记
原文地址:http://blog.csdn.net/lxf_44944/article/details/43794707