Kotlin-单例模式

单例模式

常见的单例模式,有五种。分别为:饿汉模式懒汉模式线程安全线程不安全)、双重检测模式静态内部类模式

饿汉模式

object MySingleton {

}

kotlin中使用 object 就声明了一个单例。经过object修饰过的类就是一个静态类,默认实现了饿汉模式。写法简明,不过存在类加载慢的缺点。

懒汉模式

线程不安全

kotlin默认懒汉写法:

class MySingleton private constructor() {
    companion object {
        val mInstance by lazy(mode = LazyThreadSafetyMode.NONE) {
            MySingleton()
        }
    }
}

类java懒汉写法:

class MySingleton private constructor() {
    companion object {
        private var mInstance: MySingleton? = null
        
        fun getInstance(): MySingleton {
            if (mInstance == null) {
                mInstance = MySingleton()
            }
            return mInstance!!
        }
    }
}

通过上述例子,会发现getInstance()方法会判断是否为空。如果多线程中,同时执行调用操作,会新建多个MySingleton对象,不满足一个实例的要求。

线程安全

class MySingleton private constructor() {
    companion object {
        private var mInstance: MySingleton? = null@Synchronized
        fun getInstance(): MySingleton {
            if (mInstance == null) {
                mInstance = MySingleton()
            }
            return mInstance!!
        }
    }
}

通过 @Synchronized 注解,保证多线程中,只有一个实例。
不过,虽保证了线程安全,但每次getInstance()都需要检测同步,造成一些开销。

双重检测模式

class MySingleton private constructor() {companion object {
        val mInstance by lazy(mode = LazyThreadSafetyMode.SYNCHRONIZED){
            MySingleton()
        }
    }
}

静态内部类单例模式

class MySingleton private constructor() {companion object {
        fun getInstance() = Holder.mInstance
    }object Holder {
        val mInstance: MySingleton = MySingleton()
    }
}

类加载时,没有声明mInstance变量,只有第一次调用时,才会创建mInstance实例,并且是静态的,只创建一次。

此方法,在内存优化上、安全性上都得到了很好的保障,推荐使用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值