手写单例模式

单例模式是一种常见的设计模式,确保一个类只有一个实例,并提供一个全局访问点来访问这个实例。以下是几种常见的单例模式的实现方式:

  1. 饿汉式单例模式:在类加载时就创建单例实例,是线程安全的。
public class EagerSingleton {
    // 静态成员变量,在类加载时就初始化实例
    private static final EagerSingleton instance = new EagerSingleton();

    // 私有构造函数,防止外部实例化
    private EagerSingleton() {}

    // 公共的静态方法,用于获取单例实例
    public static EagerSingleton getInstance() {
        return instance;
    }
}
  1. 懒汉式单例模式(线程不安全):在第一次调用 getInstance 方法时才创建实例,但这种方式在多线程环境下是不安全的,可能会创建多个实例。
public class LazySingleton {
    // 静态成员变量,用于存储单例实例
    private static LazySingleton instance;

    // 私有构造函数,防止外部实例化
    private LazySingleton() {}

    // 公共的静态方法,用于获取单例实例
    public static LazySingleton getInstance() {
        if (instance == null) {
            instance = new LazySingleton();
        }
        return instance;
    }
}
  1. 懒汉式单例模式(线程安全,使用 synchronized:通过在 getInstance 方法上添加 synchronized 关键字来保证线程安全,但这种方式在每次调用 getInstance 方法时都会进行同步,性能较低。
public class SynchronizedLazySingleton {
    // 静态成员变量,用于存储单例实例
    private static SynchronizedLazySingleton instance;

    // 私有构造函数,防止外部实例化
    private SynchronizedLazySingleton() {}

    // 公共的静态方法,用于获取单例实例,添加synchronized保证线程安全
    public static synchronized SynchronizedLazySingleton getInstance() {
        if (instance == null) {
            instance = new SynchronizedLazySingleton();
        }
        return instance;
    }
}
  1. 懒汉式单例模式(线程安全,双重检查锁):使用双重检查锁(DCL)来提高性能,只有在实例为 null 时才进行同步,减少了同步的开销。同时,使用 volatile 关键字来防止指令重排序,确保实例的正确初始化。
public class DoubleCheckLazySingleton {
    // 静态成员变量,使用volatile防止指令重排序
    private static volatile DoubleCheckLazySingleton instance;

    // 私有构造函数,防止外部实例化
    private DoubleCheckLazySingleton() {}

    // 公共的静态方法,用于获取单例实例,双重检查锁保证线程安全和性能
    public static DoubleCheckLazySingleton getInstance() {
        if (instance == null) {
            synchronized (DoubleCheckLazySingleton.class) {
                if (instance == null) {
                    instance = new DoubleCheckLazySingleton();
                }
            }
        }
        return instance;
    }
}
  1. 静态内部类单例模式:利用静态内部类的特性,在外部类加载时,静态内部类不会被加载,只有在调用 getInstance 方法时,静态内部类才会被加载并初始化实例,保证了线程安全和懒加载。
public class StaticInnerClassSingleton {
    // 私有构造函数,防止外部实例化
    private StaticInnerClassSingleton() {}

    // 静态内部类,用于存储单例实例
    private static class SingletonHolder {
        private static final StaticInnerClassSingleton instance = new StaticInnerClassSingleton();
    }

    // 公共的静态方法,用于获取单例实例
    public static StaticInnerClassSingleton getInstance() {
        return SingletonHolder.instance;
    }
}
  1. 枚举单例模式:使用枚举来实现单例模式,这是最简单且最安全的方式,因为枚举在 Java 中天然是线程安全的,并且只会被实例化一次。
public enum EnumSingleton {
    INSTANCE;


    public void doSomething() {
        System.out.println("执行单例实例的方法");
    }
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值