Kotlin 5种单例模式

在Kotlin中实现单例模式有多种方法,以下是几种常见的方法:

  1. 饿汉式
    饿汉式是最简单的一种实现方式,在类加载时就完成了实例的初始化。

    //饿汉式
    object Singleton1 {
    fun printMessage() {
    println("===饿汉式")
    }
    }

  2. 懒汉式
    懒汉式是延迟加载的方式,只有在第一次使用时才创建实例。

    class Singleton2 private constructor() {

    复制代码
     companion object {
         private var instance: Singleton2? = null
    
         @Synchronized
         fun getInstance(): Singleton2 {
             if (instance == null) {
                 instance = Singleton2()
    
             }
             return instance!!
         }
     }
    
     fun printMessage() {
         println("===懒汉式")
     }

    }

  3. 双重检查锁定
    双重检查锁定是一种更高效的懒汉式实现,通过双重检查锁定来确保线程安全。

    class Singleton3 private constructor() {

    复制代码
     companion object {
         private var instance: Singleton3? = null;
         fun getInstance(): Singleton3 {
             if (instance == null) {
                 synchronized(Singleton3::class.java) {
                     if (instance == null) {
                         instance = Singleton3()
                     }
                 }
             }
             return instance!!
         }
     }
    
     fun printMessage() {
         println("===双重检查锁定")
    
     }

    }

  4. 静态内部类
    静态内部类是实现单例模式的另一种方式,利用了Java的类加载机制来保证线程安全。

    //静态内部类
    class Singleton4 private constructor() {

    复制代码
     companion object {
         private var instance: Singleton4? = null
         fun getInstance(): Singleton4 {
             return Holder.instance
         }
    
         private object Holder {
             val instance = Singleton4()
         }
     }
     fun printMessage() {
         println("===静态内部类")
     }

    }

  5. 枚举
    枚举是实现单例模式的最佳方法,它天生就是线程安全的,并且能够防止反序列化创建新的对象。

    //枚举
    enum class Singleton5 {

    复制代码
     INSTANCE;
    
     fun printMessage() {
         println("===枚举")
     }

    }

    fun main() {
    Singleton1.printMessage()
    Singleton2.getInstance().printMessage()
    Singleton3.getInstance().printMessage()
    Singleton4.getInstance().printMessage()
    Singleton5.INSTANCE.printMessage()
    }
    打印结果:
    ===饿汉式
    ===懒汉式
    ===双重检查锁定
    ===静态内部类
    ===枚举

以上就是在Kotlin中实现单例模式的几种常见方法。每种方法都有其优缺点,可以根据具体的需求选择合适的方法。

相关推荐
会跑的葫芦怪5 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
xiaoqi9226 小时前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233226 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头88218 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas1368 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
2601_949833398 小时前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter
军军君019 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
xiaoqi92210 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
qq_1777673710 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
2603_9494621010 小时前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter