创建型模式就是帮助我们建一些相关的对象,单例模式就是其中的一种。
单例模式:就是一个类只有一个对象,并且提供一个方法访问这个对象。
单例只需要生成一个实例,所以内存占用和系统开销比较小,对于一些资源共享和初始化比较慢的资源处理时候,我们可以用单例模式来做。
饿汉式的特点:线程安全,调用效率高。缺陷是不能延时加载。一般希望延时加载。饿汉式一般实现要注意三点,第一要私有构造器,把构造器私有了,别人就访问不了,只能自己访问,第二提供一个属性,这个属性是静态的,并且也是私有的,静态属性属于类,第三提供提供一个开放的方法,别人只能从这个开放的方法取对象,不管访问几次都是这个对象。
练习
package com.cb.study01;
/*
* 测试饿汉式单例模式
*/
public class SingletonDemo01 {
//类初始化时,立即加载这个对象(没有延时加载的优势)。加载类时,天然的线程安全
private static SingletonDemo01 instance = new SingletonDemo01();
//私有构造器
private SingletonDemo01(){
}
//方法没有同步,调用效率高
public static SingletonDemo01 getInstance(){
return instance;
}
}
什么要叫它饿汉式,饿汉的特点很饿,一上来就要吃东西,当我类加载器加载类的时候,加载这个对象就把这对象 new出来,不管后面要不要有没有使用这个类,上来就创建好。如果后面没有用这个对象那就白加载了,所以我们希望延时加载,就是不用的时候不加载,用的时候在加载。
为什么说它是线程安全,这个方法前面不需要加synchronized,类在初始化的时候立即加载,它是一个天然线程安全,不需要加synchronized就不用等,它就调用效率高。
懒汉式:它和饿汉式不一样的是,它没有初始化,当调用方法的在去new这个类,当第二次的就存在这个对象,就可以直接返回这个对象,因为可能存在多个线程调用,就需要加synchronized同步,避免第一次调用这个方法产生多个对象,就违反建立单例模式的初衷了,所以要加synchronized。加了synchronized并发效率就低,每
为什么叫懒汉式,比如昨天要交作业,就等到要交作业的时候在去赶作业,就是懒汉,这个对象要用的在去调用,所以就加懒汉式。
练习:
package com.cb.study01;
/*
* 测试懒汉式单例模式
*/
public class SingletonDemo02 {
//类初始化时,不初始化这个对象(延时加载,真正用的时候再创建)。
private static SingletonDemo02 instance;
//私有构造器
private SingletonDemo02(){
}
//方法同步,调用效率低
public synchronized static SingletonDemo02 getInstance(){
if (instance==null) {
instance = new SingletonDemo02();
}
return instance;
}
}