单例实现多方式

是什么?

是什么:单例模式是一种非常常用的软件设计模式,它定义是单例对象的类只能允许一个实例存在
单例模式特点:

  1. 类构造器私有
  2. 持有自己类的引用
  3. 对外提供获取实例的静态方法

实现方式

饿汉模式

/**
 * 饿汉模式,无线程安全问题;浪费内存空间
 */
public class SimpleSingleton {
    private static final SimpleSingleton INSTANCE = new SimpleSingleton();

    private SimpleSingleton() {
    }

    public  static  SimpleSingleton getInstance(){
        return INSTANCE;
    }
}

懒汉模式(饱汉模式)

package com.study.po;

/**
 * 懒汉模式
 * 没有内存空间浪费问题,多线程下可能就不是单例了
 */
public class SimpleSingleton2 {
    //volatile关键字可以保证多个线程的可见性,但是不能保证原子性。同时它也能禁止指令重排
    private volatile static SimpleSingleton2 INSTANCE;
    
    private SimpleSingleton2() {
    }
    
    public static SimpleSingleton2 getInstance() {
        //判断是不是为空,不为空不用枷锁
        if (INSTANCE == null) {
            synchronized (SimpleSingleton2.class) {
                //为了防止多线程并发情况下,只实例化一次
                //比如:线程a和线程b同时调用getInstance方法,假如同时判断INSTANCE都为空,这时会同时进行抢锁。
                //假如线程a先抢到锁,开始执行synchronized关键字包含的代码,此时线程b处于等待状态。
                //线程a创建完新实例了,释放锁了,此时线程b拿到锁,进入synchronized关键字包含的代码,如果没有再判断一次INSTANCE是否为空,则可能会重复创建实例。
                if (INSTANCE == null)
                    INSTANCE = new SimpleSingleton2();
            }

        }
        return INSTANCE;
    }

}

静态内部类

import java.io.ObjectStreamException;
import java.io.Serializable;

/**
 * 单例使用静态内部类方式
 */
public class SimpleSingleton3 implements Serializable {


    private SimpleSingleton3() {
        //反射漏洞
        if (Inner.INSTANCE != null) {
            throw new RuntimeException("重复实例化");
        }

    }

    public static SimpleSingleton3 getInstance() {
        return Inner.INSTANCE;
    }

    private static class Inner {
        private static final SimpleSingleton3 INSTANCE = new SimpleSingleton3();
    }
    //反序列化漏洞
    private Object readResolve() throws ObjectStreamException {
        return Inner.INSTANCE;
    }


}

枚举

单元素的枚举类型已经成为实现Singleton的最佳方法。

public enum SimpleSingleton4 {

    INSTANCE,INSTANCE2;
    private Person person;

    SimpleSingleton4() {
        person = new Person();
    }

    public  Person getPerson() {
        return person;
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值