Kotlin中单例模式和Java的对比浅析
前言
单例模式,一直以来是我们在日常开发中最常用的一种设计模式,更是面试中非常重要,也非常容易被问到的问题。在日常开发中,大家常用的语言还是Java,但今天我给大家带来的是在Kotlin语言中,单例模式是怎么编写的,并且会对比Java方式,下面话不多说了,来一起看看详细的介绍吧
一、懒人写法(恶汉式)
java中
publicclassSingleton{ publicstaticfinalSingletoninstance=newSingleton(); publicSingletongetInstance(){ returninstance; } }
kotlin中
最简单的写法,直接用object声明
objectSingleton{}
二、基本懒加载(未实现线程同步)
注:这种方式实现了懒加载,但是不是线程安全的,可能在多个线程中创建多个不同的实例
java中
publicclassSingleton{ publicstaticSingletoninstance=null; privateSingleton(){} publicSingletongetInstance(){ if(instance==null){ instance=newSingleton(); } returninstance; } }
kotlin中
classSingletonprivateconstructor{ companionobject{ valintancebylazy(LazyThreadSafetyMode.NONE){Singleton()} } }
三、线程同步单例1
注:其实kotlin这种写法可以说是java直译过来的,虽说是线程安全的,但是太影响效率,主要看下面这种
java中
publicclassSingleton{ privatestaticSingletoninstance=null; privateSingleton(){} publicstaticsynchronizedSingletongetInstance(){ if(instance==null){ instance=newSingleton(); } returninstance; } }
kotlin中
classSingletonprivateconstructor(){ companionobject{ lateinitvarinstance:Singleton @Synchronized funget():Singleton{ if(instance==null){ instance=Singleton(); } returninstance!! } } }
四、线程同步单例2
注:线程同步,懒加载,无同步引起的效率问题
java中双检锁单例
publicclassSingleton{ privatestaticSingletoninstance=null; privateSingleton(){} publicstaticSingletongetInstance(){ if(instance==null){ synchronized(Singleton.class){ if(instance==null){ instance=newSingleton(); } } } returninstance; } }
kotlin
classSingletonprivateconstructor(){ companionobject{ valintancebylazy(LazyThreadSafetyMode.SYNCHRONIZED){Singleton()} } }
五、静态内部类单例
java中
publicclassSingleton{ privateSingleton(){} privatestaticclassHolder{ privatestaticSingletoninstance=newSingleton(); } publicstaticSingletongetInstance(){ returnHolder.instance; } }
kotlin中
classSingletonprivateconstructor(){ companionobject{ fungetInstance():Singleton{ returnHolder.instance } } privateobjectHolder{ valinstance=Singleton() } }
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。