代码如下:
/**
* Created on 2017/5/5.
* Author:crs
* Description:使用静态内部类的方式实现单例模式
*/
public class Singleton {
private Singleton() {
}
public static final Singleton getInstance() {
return SingletonHolder.INSTANCE;
}
public static class SingletonHolder {
private static final Singleton INSTANCE = new Singleton();
}
}
1) 如何保证线程安全: 因为内部的静态类只会被加载一次,只会有一个实例对象,所以是线程安全的
2) 内部类的加载机制: java中的内部类是延时加载的,只有在第一次使用时加载;不使用就不加载;
类的加载机制: 虚拟机在首次加载Java类时,会对静态初始化块、静态成员变量、静态方法进行一次初始化;静态内容首先被加载,相当于全局的成员变量。
当静态方法getInstance()加载时,SingletonHolder.INSTANCE默认初始值是空的,只有当调用次方法时,内部类才会被实例化。
Singleton类被装载了,instance不一定被初始化,因为它是内部类中的成员。因为SingletonHolder类没有被主动使用,只有显示通过调用getInstance方法时,才会显示装载SingletonHolder类,从而实例化instance。
如果实例化instance很消耗资源,我想让他延迟加载,另外一方面,我不希望在Singleton类加载时就实例化,因为我不能确保Singleton类还可能在其他的地方被主动使用从而被加载,那么这个时候实例化instance显然是不合适的。
利用了classloader的机制来保证初始化instance时只有一个线程,所以也是线程安全的,同时没有性能损耗。
final修饰的方法,不能被重写;当子类继承时此方法不能被修改。
由final修饰的变量是常量,常量名全部大写。