单例模式的懒汉式如何测试线程是否安全

本文探讨了懒汉式单例模式的线程安全性问题,通过在`getInstance`方法中使用同步锁确保多线程环境下实例的唯一性。然而,这种方法可能导致不必要的性能开销。为解决这一问题,文章提出了在外层进行非空判断的优化方案,避免了多个线程重复创建实例。通过测试验证,改进后的`getInstance1`方法能确保在并发调用时返回相同的单例实例。
摘要由CSDN通过智能技术生成

/**

  • 线程安全的懒汉式
    */
    public class SingletonThread {
    private static SingletonThread instance;
    private SingletonThread() {
    }
    // 1.多线程情况下加锁,保证多个线程同时访问时,不会创建多个实例
    // 2.然而这段代码的问题是每次调用getInstance方法都会加锁,会造成性能浪费
    public static SingletonThread getInstance(){
    synchronized (SingletonThread.class){
    if (instance == null) {
    instance = new SingletonThread();
    }
    return instance;
    }
    }

    // 3.因此在外层再判断一遍是否有实例,没有再放线程进去
    // 4.为什么里外层都做是否有实例的判断,是因为如果是两个或多个线程,它们都会进入第一个判断,此时因为锁,
    // 第一个线程进去做下一步判断并创建了实例,而第二线程在等待第一个线程结束之后也会接着执行,此时如果没有
    // 非空判断,它就会又实例一个对象,就不是单例了
    public static SingletonThread getInstance1(){
    if (instance == null) {
    synchronized (SingletonThread.class){
    if (instance == null) {

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值