(GOF23设计模式)_单例模式_应用场景_饿汉式_懒汉式

设计模式

a、创建型模式

单例模式、工厂模式、抽象工厂模式、建造者模式、原型模式

b、结构型模式

适配器模式、桥接模式、装饰模式、组合模式、外观模式、享元模式、代理模式

c、行为型模式

模板方法模式、命令模式、迭代器模式、观察者模式、中介者模式、备忘录模式、解释器模式、
状态模式、策略模式、职责链模式、访问者模式

1、单例模式

核心作用:
保证一个类只有一个实例,并且提供一个访问该实例的全局访问点

2、单例模式的优点:

由于单例模式只生成一个实例,减少了系统性能开销,当一个对象的产生需要比较多的资源时,如读取配置,产生其他依赖对象时,则可以通过
在应用启动时直接产生一个单例对象,然后永久驻留内存的方式来解决

单例模式可以在系统设置全局的访问点,优化环共享资源访问,例如可以设计一个单例类,负责所有数据表的映射处理

3、常见的五种单例模式实现方式:

主要:
饿汉式(线程安全,调用效率高。但是,不能延时加载)
懒汉式(线程安全,调用效率不高。但是,可以延时加载)

其他:
双重检测锁式(由于JVM底层内部模型原因,偶尔会出问题。不建议使用)
静态内部类式(线程安全,调用效率高。但是,可以延时加载)
枚举单例(线程安全,调用效率高,不能延时加载)

4、饿汉式实现(单例对象立即加载)

SingletonDemo01.java

package junit.matrix.pattern.singleton;

/**
 * 测试饿汉式单例模式
 * 
 * SingletonDemo01<BR>
 * 创建人:Matrix <BR>
 * 时间:2016年2月23日-下午4:55:50 <BR>
 * 
 * @version 1.0.0
 *
 */
public class SingletonDemo01 {

	// 类初始化时,立即加载这个对象(没有延时加载的优势)。加载类时,天然的是线程安全的!
	private static SingletonDemo01 instance = new SingletonDemo01();
    
    // 私有化构造器
	private SingletonDemo01() {

	}

	// 方法没有同步,调用效率高!
	public static SingletonDemo01 getInstance() {
		return instance;
	}
}

饿汉式单例模式代码中,static变量会在类装载时初始化,此时也不会涉及多个线程对象访问该对象的问题。虚拟机保证只会装载一次该类,肯定不会发生并发访问的问题。因此,可以省略synchronized关键字。

问题:如果只是加载本类,而不是要调用getInstance(),甚至永远没有调用,则会造成资源浪费!

5、懒汉式实现(单例对象延迟加载)

SingletonDemo02.java

package junit.matrix.pattern.singleton;

/**
 * 测试懒汉式单例模式
 * 
 * SingletonDemo02<BR>
 * 创建人:Matrix <BR>
 * 时间:2016年2月23日-下午5:40:58 <BR>
 * 
 * @version 1.0.0
 *
 */
public class SingletonDemo02 {

	// 类初始化时,不初始化这个对象(延时加载,真正用的时候再创建)
	private static SingletonDemo02 instance;

	// 私有化构造器
	private SingletonDemo02() {

	}

    // 方法同步,调用效率低!
	public static synchronized SingletonDemo02 getInstance() {
		if (instance == null) {
			instance = new SingletonDemo02();
		}
		return instance;
	}
}

要点:

lazy load! 延迟加载,懒加载!真正用的时候才加载!

问题:

资源利用率高了。但是,每次调用getInstance()方法都要同步,
(调用效率低了,多个线程调用的话需要等待,因为一次只有一个线程能运行)并发效率较低。
原文地址:https://www.cnblogs.com/SparseMatrix/p/5210800.html