设计模式_1_单例模式_饿汉懒汉
创建型模式就是帮助我们建一些相关的对象,单例模式就是其中的一种。
单例模式:就是一个类只有一个对象,并且提供一个方法访问这个对象。 单例只需要生成一个实例,所以内存占用和系统开销比较小,对于一些资源共享和初始化比较慢的资源处理时候,我们可以用单例模式来做。 饿汉式的特点:线程安全,调用效率高。缺陷是不能延时加载。一般希望延时加载。饿汉式一般实现要注意三点,第一要私有构造器,把构造器私有了,别人就访问不了,只能自己访问,第二提供一个属性,这个属性是静态的,并且也是私有的,静态属性属于类,第三提供提供一个开放的方法,别人只能从这个开放的方法取对象,不管访问几次都是这个对象。
练习
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; } }