Kotlin中单利常用的五种写法
前言
单利模式是写代码过程中不可避免用到的,下面我总结一下单利常用的五种写法,话不多说了,来一起看看详细的介绍吧
加载类时创建单利
Java实现
public class Config{ private static Config INSTANCE=new Config(); private Config(){ //构造函数 } public static Config getInstance(){ return INSTANCE; } }
Kotlin实现
object Config{}
上面这种写法简单粗暴,直接在加载类的时候创建,但这样会拖慢启动进程,因此,可以在用到的时候再加载,比如下面这种写法
懒加载写法
Java实现
public class Config{ private static Config INSTANCE; private Config(){ //构造函数 } public static Config getInstance(){ if(null==INSTANCE){ INSTSANCE=new Config(); } return INSTANCE; } }
Kotlin实现
public class Config{ companion object{ val instance by lazy(LazyThreadSafetyMode.NONE){ Config() } } }
懒加载虽然避免在加载类的时候创建,但是线程不安全,如果同时多个类获取单利,有可能会创建多个单利,因此可以在创建单利的时候加线程锁,比如下面这种写法:
同步锁写法
Java实现
public class Config{ private static Config INSTANCE; private Config(){ //构造函数 } public static synchronized Config getInstance(){ if(null==INSTANCE){ INSTANCE=new Config(); } return INSTANCE; } }
Kotlin实现
class Config{ companion object{ private var instance:Config?=null @Synchronized fun get():Config{ if(nnull==instance) instance=Config() return instance } } }
同步锁避免单利不会被重复创建,但是同步锁
双重校验写法
Java实现
public class Config{ private static volatile Config INSTANCE; private Config(){ //构造函数 } public static Config getInstance(){ if(null==INSTANCE){ synchronized(Config.class){ if(null==INSTANCE){ INSTSANCE=new Config(); } } } return INSTANCE; } }
Kotlin实现
class Config{ companion object{ val instance by lazy(LazyThreadSafetyMode.SYNCHRONIZED){ Config() } } }
静态内部类写法
这种写法避免了类加载的时候初始化单利,同时将同步锁问题交给虚拟机处理,算得上是最优雅的写法,Java和Kotlin写法几乎是一模一样
Java实现
public class Config{ private static class Helper{ private static Config INSTANCE=new Config(); } private Config(){ //构造函数 } public static Config getInstance(){ return Helper.INSTANCE; } }
Kotlin实现
class Config private constructor(){ companion object{ fun getInstance = Helper.instance } private object Helper{ val instance = Config() } }
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。
赞 (0)