单例模式有三个要点:一是此类只能有一个实例;二是它必须自行创建这个实例;三是它必须自动向整个系统提供这个实例。
Java的单例类有以下两种模型:
1、饿汉式单例类
有一个静态成员,是指向本类的句柄,它也将是这个类的唯一一个实例。这个句柄在一开始就被初始化,也就是说这个单例被早早地准备好了;
构造函数是私有的,这样可以保证除了它自己,没有任何类可以构造它的实例。
有一个public函数用于返回类的实例,它是静态的。
2、懒汉式单例类
有一个静态成员,是指向本类的句柄,它也将是这个类的唯一一个实例。这个句柄在初始化时为空,也就是说单例没有被准备好;
构造函数也是私有的,这样可以保证除了它自己,没有任何类可以构造它的实例。
有一个静态的public函数用于返回类的实例,当它被调用来返回一个实例时,会先判断实例是否创造好了,如果没有的话,现做。此外,它还必须是synchronized的,每次只能有一个类来调用它,因为如果有多人同时调用,而此前没有被调用过的话,会实例可能会被创建多次。
Java的单例类有以下两种模型:
1、饿汉式单例类
有一个静态成员,是指向本类的句柄,它也将是这个类的唯一一个实例。这个句柄在一开始就被初始化,也就是说这个单例被早早地准备好了;
构造函数是私有的,这样可以保证除了它自己,没有任何类可以构造它的实例。
有一个public函数用于返回类的实例,它是静态的。
package
singleton;
public class EagerSingleton ... {
private static EagerSingleton onlyInstance = new EagerSingleton();
private EagerSingleton() ...{
}
public static EagerSingleton getInstance() ...{
return onlyInstance;
}
}
public class EagerSingleton ... {
private static EagerSingleton onlyInstance = new EagerSingleton();
private EagerSingleton() ...{
}
public static EagerSingleton getInstance() ...{
return onlyInstance;
}
}
有一个静态成员,是指向本类的句柄,它也将是这个类的唯一一个实例。这个句柄在初始化时为空,也就是说单例没有被准备好;
构造函数也是私有的,这样可以保证除了它自己,没有任何类可以构造它的实例。
有一个静态的public函数用于返回类的实例,当它被调用来返回一个实例时,会先判断实例是否创造好了,如果没有的话,现做。此外,它还必须是synchronized的,每次只能有一个类来调用它,因为如果有多人同时调用,而此前没有被调用过的话,会实例可能会被创建多次。
package
singleton;
public class LazySingleton ... {
private static LazySingleton onlyInstance = null;
private LazySingleton() ...{
}
synchronized public static LazySingleton getInstance() ...{
if (onlyInstance == null)
onlyInstance = new LazySingleton();
return onlyInstance;
}
}
public class LazySingleton ... {
private static LazySingleton onlyInstance = null;
private LazySingleton() ...{
}
synchronized public static LazySingleton getInstance() ...{
if (onlyInstance == null)
onlyInstance = new LazySingleton();
return onlyInstance;
}
}