第三条:用私有构造器或者枚举类型强化Singleton属性
Singleton指仅仅被实例化一次的类,通常被用来代表那些本质上唯一的系统组件
public class SingletonTest {
public static final SingletonTest INSTANCE = new SingletonTest();
private SingletonTest() {}
}
私有构造器仅被调用一次,用来实例化共有的静态final域的SingletonTest.INSTANCE。由于缺少公有的或者受保护的构造器,所以保证了SingletonTest的全局唯一性:一旦SingletonTest被实例化,只会存在一个SingletonTest实例,但是可以借助AccessibleObject.setAccessible方法,通过反射机制,调用私有构造器,如果需要抵御这种攻击,可以修改构造器,使用以下方法:
public class SingletonTest {
private static final SingletonTest INSTANCE = new SingletonTest();
private SingletonTest() {}
public static SingletonTest getInstance() {return INSTANCE;}
}
对于静态方法SingletonTest.getInstance()的所有调用,都会返回同一个对象实例
第四条:通过私有构造器强化不可实例化的能力
有时候,你可能需要编写只包含静态方法和静态域的类,比如一些工具类,这样的类不希望被实例化,实例对它没有任何意义,企图通过将类做成抽象类来强制该类不可被实例化,这是行不通的 反而会被以为这种类是专门为了继承而设计的,正确的做法是,让这个类包含私有构造器,它就不能被实例化了:
public class Utils {
private Utils() {
//AssertionError不是必需的
throw new AssertionError();
}
//工具方法
public static void method() {}
.......
.......
}
AssertionError不是必需的,但是它可以避免不小心在类的内部调用构造器。
第五条:避免创建不必要的对象