最完美的单例模式

本文探讨了四种Java单例模式实现方式:饿汉式、懒汉式(包括加锁和双重检查)、静态内部类和枚举方式。饿汉式在类加载时创建单例,简单但不适用于所有场景。懒汉式关注线程安全和效率,双重检查机制引入了volatile。静态内部类在首次访问时创建单例,兼顾延迟初始化和线程安全。而枚举方式,如Effective Java推荐,既能确保线程安全又防止反序列化问题。
摘要由CSDN通过智能技术生成

在工作中用最常用的选择是饿汉式和双重检查懒汉式。最完美的是Effective Java中推荐的enum方式

1、恶汉式:
      类加载到内存中,就实例化一个单例,JVM保证线程安全,简单实用
      一个小缺点:无论用到与否,类加载时就完成实例化

public class HungrySingleton {
    private static final HungrySingleton INSTANCE = new HungrySingleton();

    private HungrySingleton() {
    }

    public static HungrySingleton getInstance() {
        return INSTANCE;
    }

2、懒汉式

一个是在静态方法上加锁,相当于锁定了整个类,可能会对效率有影响

public class LazySingleton1 {

    private static  LazySingleton1 INSTANCE;

    private LazySingleton1() {
    }

    /**
     * 1、静态方法加锁,锁定了LazySingleton
     *
     * @return
     */
    public static synchronized LazySingleton1 getInstance1() {
        if (INSTANCE == null) {
            INSTANCE = new LazySingleton1();
        }
        return INSTANCE;
    }

双重检查机制:要加volatile,防止JVM的指令重排

public 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值