Kotlin中的几种单例模式
2021/7/3 13:21:18
本文主要是介绍Kotlin中的几种单例模式,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1. 常见的几种单例模式
单例模式是我们日常用到的频率比较高的设计模式,常见有以下几种类型:
1 饿汉单例
2 懒汉单例
3 线程安全的懒汉单例
4 双重校验模式
5 静态内部类模式
这篇文章主要介绍一下这几种单例模式在Java以及Kotlin中的不同实现方式
2. 饿汉单例
//Java实现 public class SingletonDemo { private static SingletonDemo instance=new SingletonDemo(); private SingletonDemo(){ } public static SingletonDemo getInstance(){ return instance; } } //Kotlin实现 object SingletonDemo
没错,kotlin中实现饿汉单例只需要在类名前面加上一个object关键字就可以了。因为kotlin中是没有静态方法的概念的,所以就没有办法创建类似java实现方式中的getInstance()这样的静态方法。但是kotlin提供了更加简洁的方式达到相同的效果,就是使用object关键字。、
3. 懒汉单例
//Java实现 public class SingletonDemo { private static SingletonDemo instance; private SingletonDemo(){} public static SingletonDemo getInstance(){ if(instance==null){ instance=new SingletonDemo(); } return instance; } } //Kotlin实现 class SingletonDemo private constructor() { companion object { private var instance: SingletonDemo? = null //这里使用的是自定义访问器 get() { if (field == null) { field = SingletonDemo() } return field } fun get(): SingletonDemo{ return instance!! } } }
kotlin实现懒汉单例的关键点有两个:1 主构造器私有化 2 使用自定义访问器返回对象实例
4. 线程安全的懒汉单例
//Java实现 public class SingletonDemo { private static SingletonDemo instance; private SingletonDemo(){} //为方法添加同步锁 public static synchronized SingletonDemo getInstance(){ if(instance==null){ instance=new SingletonDemo(); } return instance; } } //Kotlin实现 class SingletonDemo private constructor() { companion object { private var instance: SingletonDemo? = null get() { if (field == null) { field = SingletonDemo() } return field } //使用同步锁注解 @Synchronized fun get(): SingletonDemo{ return instance!! } } }
内容基本与懒汉模式相同,唯一的区别就是Java使用为方法添加同步锁的方式实现,kotlin需要在方法中添加
@Synchronized注解。
5. 双重校验锁
//Java实现 public class SingletonDemo { private volatile static SingletonDemo instance; private SingletonDemo(){} public static SingletonDemo getInstance(){ if(instance==null){ synchronized (SingletonDemo.class){ if(instance==null){ instance=new SingletonDemo(); } } } return instance; } } //kotlin实现 class SingletonDemo private constructor() { companion object { val instance: SingletonDemo by lazy(mode = LazyThreadSafetyMode.SYNCHRONIZED) { SingletonDemo() } } }
Java中的双重校验锁模式就是在同步锁模式的基础上稍作改动,添加了双重判断,并且将同步锁的作用域进一步缩小到了方法内部进行第二重判断之前。而kotlin中双重校验锁的实现更加简单,直接使用lazy结合属性委托的方式实现。
6. 静态内部类模式
//Java实现 public class SingletonDemo { private static class SingletonHolder{ private static SingletonDemo instance=new SingletonDemo(); } private SingletonDemo(){ System.out.println("this is a singleton model"); } public static SingletonDemo getInstance(){ return SingletonHolder.instance; } } //kotlin实现 class SingletonDemo private constructor() { companion object { val instance = SingletonHolder.holder } private object SingletonHolder { val holder= SingletonDemo() } }
kotlin和java的实现方式基本相同
这篇关于Kotlin中的几种单例模式的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-01-06Kotlin委托属性(1)
- 2023-06-15Kotlin协程-那些理不清乱不明的关系
- 2023-06-08[Kotlin Tutorials 21] 协程的取消
- 2023-05-26Kotlin难点
- 2023-02-23【备战春招】第16天 Kotlin实用技巧
- 2023-02-23【备战春招】第15天 Kotlin扩展Extensions技术探秘
- 2023-02-22【备战春招】第14天 深入理解Kotlin注解
- 2023-02-21【备战春招】第12天 深入理解Kotlin类与接口
- 2023-02-21【备战春招】第13天 深入理解Kotlin泛型
- 2023-02-18【备战春招】第10天 Kotlin方法与Lambda表达式