2024年网络安全最新线程安全的恶汉单例实现

3.在Java中构成的条件


  • 静态变量

  • 静态方法

  • 私有构造器

二.单例模式的两种形态


1.懒汉模式

线程不安全


public class Singleton {



    private static Singleton unsingleton;



    private Singleton(){}



    public static Singleton getInstance(){

        if(unsingleton==null){

            unsingleton=new Singleton();

        }

        return unsingleton;

    }

}



2.饿汉模式

线程安全


public class Singleton {



    private static Singleton unsingleton=new Singleton();



    private Singleton(){}



    public static Singleton getInstance(){

        return unsingleton;

    }

}



调用


public class Test {

    public static void main(String[] args) {

        Singleton singleton1=Singleton.getInstance();

    }

}



三.懒汉模式优化成线程安全


懒汉模式要变成线程安全的除了用饿汉模式之外,还有两种方法。

1.加synchronized关键字

此方法是最简单又有效的方法,不过对性能上会有所损失。比如两个线程同时调用这个实例,其中一个线程要等另一个线程调用完才可以继续调用。而线程不安全往往发生在这个实例在第一次调用的时候发生,当实例被调用一次后,线程是安全的,所以加synchronized就显得有些浪费性能。


public class Singleton {



    private static Singleton unsingleton;



    private Singleton(){}



    public static synchronized Singleton getInstance(){

        if(unsingleton==null){

            unsingleton=new Singleton();

        }

        return unsingleton;

    }

}



2.用"双重检查加锁"

上个方法说到,线程不安全往往发生在这个实例在第一次调用的时候发生,当实例被调用一次后,线程是安全的。那有没有方法只有在第一次调用的时候才用synchronized关键字,而第一次后就不用synchronized关键字呢?答案是当然有的,就是用volatile来修饰静态变量,保持其可见性。


public class Singleton {



    private static volatile Singleton unsingleton;



    private Singleton(){}



    public static Singleton getInstance(){

        if(unsingleton==null){

            //只有当第一次访问的时候才会使用synchronized关键字

            synchronized (Singleton.class){

                unsingleton=new Singleton();

            }

        }

        return unsingleton;

    }

}



3. 用"静态内部类"

静态内部类的优点是:外部类加载时并不需要立即加载内部类,内部类不被加载则不去初始化INSTANCE,故而不占内存。即当SingleTon第一次被加载时,并不需要去加载SingleTonHoler,只有当getInstance()方法第一次被调用时,才会去初始化INSTANCE,第一次调用getInstance()方法会导致虚拟机加载SingleTonHoler类,这种方法不仅能确保线程安全,也能保证单例的唯一性,同时也延迟了单例的实例化。


public class Singleton {

    private Singleton() {

      }



      private static Singleton instatnce;



      private static class SingletonHolder {

        private static Singleton instatnce = new Singleton();

      }



      public static Singleton getInstance() {

        return SingletonHolder.instatnce;

      }

	}



那么,静态内部类又是如何实现线程安全的呢?首先,我们先了解下类的加载时机。

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上网络安全知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以点击这里获取
片转存中…(img-iJfR6JaM-1714748784639)]
[外链图片转存中…(img-kd1Jxf5p-1714748784640)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上网络安全知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以点击这里获取

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值