前言
对于系统中的某些类来说,只有一个实例很重要,例如,一个系统中可以存在多个打印任务,但是只能有一个正在工作的任务;一个系统只能有一个窗口管理器或文件系统;一个系统只能有一个计时工具或ID(序号)生成器。
如在Windows中就只能打开一个任务管理器。如果不使用机制对窗口对象进行唯一化,将弹出多个窗口,如果遮羞窗口显示的内容完全一致,则是重复对象,浪费内存资源;如果这些窗口显示的内容不一致,则意味着在某一瞬间系统有多个状态,与实际不符,也会给用户带来误解,不知道哪一个才是真实的状态。因此,某些情况下,确保系统中某个对象的唯一性即一个类只能有一个实例非常重要。
如何保证一个类只有一个实例并且这个实例易于被访问?定义一个全局变量可以确保对象随时都可以被访问,但不能防止我们实例化多个对象。一个更好 的解决办法是让类自身负责保存它的唯一实例、这个类可以保证没有其他实例被创建,并且它可以提供一个访问该实例的办法。
单例模式要点
单例模式的要点有三个:
1、某个类只能有一个实例(对象);
2、类必须自行创建这个实例;
3、类必须自行向整个系统提供这个实例。
单例模式目的
单例模式的目的:保证该类只有一个对象。
单例模式实现思路
思路:
1、把类中的构造方法私有(private)
2、在成员位置自己创建一个对象(即创建一个成员变量)
3、通过一个公共的方法提供访问
单例模式优点
单例模式有如下优点:
1、实例控制:单例模式会阻止其他对象实例化其自己的单例对象的副本,从而确保所有对象都访问唯一实例
2、灵活性:因为类控制了实例化过程,所以类可以灵活更改实例化过程。
单例模式代码示例
Singleton模式只要作用是保证Java应用程序中,一个类class只有一个实例存在。一般Singleton模式通常有两种形式。
第一种形式俗称“懒汉式”,也是常用的形式。
// 懒汉式
public class SingleInstance {
private static SingleInstance instance = null;
// 无参构造函数
private SingleInstance() {
}
public static synchronized SingleInstance getInstance() {
if(instance == null) {
instance = new SingleInstance();
}
return instance;
}
}
第二种形式俗称“饿汉式”
public class Singleton {
// 饿汉式
private static final Singleton instance = new Singleton();
// 无参构造函数
private Singleton() {
}
public static Singleton getInstance() {
return instance;
}
}
懒汉式和饿汉式的区别
1、懒汉式是线程安全的,在类创建的同时就已经创建好了一个静态的供对象系统使用,以后不再改变。懒汉式如果在创建实例对象时不加上synchronized 则会导致对对象的访问不是线程安全的。
2、从实现方式来讲他们最大的区别就是懒汉式是延时加载,他是在需要的时候才创建对象,而饿汉式在虚拟机启动的时候就会创建,饿汉式无需关注多线程问题、写法简单明了、能用则用。但是它是加载类时创建实例,所以如果是一个工厂模式、缓存了很多实例,那么就要考虑效率问题,因为这个类一加载就把所有实例不管用不用都一块创建。