当前位置: 首页 > article >正文

Kotlin 5种单例模式

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

  1. 饿汉式
    饿汉式是最简单的一种实现方式,在类加载时就完成了实例的初始化。
//饿汉式
object Singleton1 {
    fun printMessage() {
        println("===饿汉式")
    }
}
  1. 懒汉式
    懒汉式是延迟加载的方式,只有在第一次使用时才创建实例。
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("===懒汉式")
    }
}

  1. 双重检查锁定
    双重检查锁定是一种更高效的懒汉式实现,通过双重检查锁定来确保线程安全。
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("===双重检查锁定")

    }
}

  1. 静态内部类
    静态内部类是实现单例模式的另一种方式,利用了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("===静态内部类")
    }
}
  1. 枚举
    枚举是实现单例模式的最佳方法,它天生就是线程安全的,并且能够防止反序列化创建新的对象。
//枚举
enum class Singleton5 {

    INSTANCE;

    fun printMessage() {
        println("===枚举")
    }

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

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


http://www.kler.cn/a/573639.html

相关文章:

  • 【2025.3最新版】从零开始的CSS网页开发学习笔记 1(包含CSS简介 CSS基础选择器 CSS字体属性 CSS文本属性 CSS引入方式)
  • WHAT - 前端异步事件流处理场景梳理
  • 详细探索如何用脚本实现M小ySQL一键安装与配置,提升运维效率!
  • LLaMA-2 7B 简介
  • Vue输入框获取焦点
  • 【深度学习】—— 深入 Keras:从基础到实战的深度学习指南 第11章 共12章
  • 聊一聊 IM 要如何提升用户体验?
  • 五、Redis 持久化:RDB 与 AOF 深入解析与优化策略
  • 深入探索 jvm-sandbox 与 jvm-sandbox-repeater 在微服务测试中的应用
  • 蓝桥杯每日一题:第一周周四哞叫时间
  • 前端大文件上传
  • ZYNQ-PL学习实践(二)按键和定时器控制LED闪烁灯
  • MDM 如何彻底改变医疗设备的远程管理
  • MacOS 10.15上使用Docker遇到的几个问题
  • js操作字符串的常用方法
  • DeepSeek 助力 Vue3 开发:打造丝滑的表格(Table)示例4: 自定义插槽
  • vulnhub靶场之【digitalworld.local系列】的mercy靶机
  • 有关Java中的集合(1):List<T>和Set<T>
  • 一文学会Spring
  • WEB12~13