kotlin实现java的单例模式
代码
package com.flannery.interviewdemo.singleinstance//https://blog.csdn.net/Jason_Lee155/article/details/128796742
Java实现
//public class SingletonDemo {
// private static SingletonDemo instance=new SingletonDemo();
// private SingletonDemo()
// {
//
// }
// public static SingletonDemo getInstance()
// {
// return instance;
// }
//}
// 饿汉式
object SingleInstance1// 懒汉式
Java实现
//public class SingletonDemo {
// private static SingletonDemo instance;
// private SingletonDemo(){}
// public static SingletonDemo getInstance(){
// if(instance==null){
// instance=new SingletonDemo();
// }
// return instance;
// }
//}
//
class SingletonDemo2 private constructor() {companion object {private var instance: SingletonDemo2? = nullget() {if (field == null) {field = SingletonDemo2()}return field}fun get(): SingletonDemo2 {//细心的小伙伴肯定发现了,这里不用getInstance作为为方法名,是因为在伴生对象声明时,内部已有getInstance方法,所以只能取其他名字return instance!!}}
}// 线程安全的懒汉式
//public class SingletonDemo {
// private static SingletonDemo instance;
// private SingletonDemo() {}
// public static synchronized SingletonDemo getInstance() {//使用同步锁
// if (instance == null) {
// instance = new SingletonDemo ();
// }
// return instance;
// }
//}
class SingletonDemo3 private constructor() {companion object {private var instance: SingletonDemo3? = nullget() {if (field == null) {field = SingletonDemo3()}return field}@Synchronizedfun get(): SingletonDemo3 {return instance!!}}}// 双重校验锁
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 SingletonDemo4 private constructor() {companion object {val instance: SingletonDemo4 by lazy(mode = LazyThreadSafetyMode.SYNCHRONIZED) {SingletonDemo4()}}
}// 静态内部类
//Java实现
//public class SingletonDemo {
// private static class SingletonHolder{
// private static SingletonDemo instance=new SingletonDemo();
// }
// private SingletonDemo(){
// System.out.println("Singleton has loaded");
// }
// public static SingletonDemo getInstance(){
// return SingletonHolder.instance;
// }
//}
//kotlin实现
class SingletonDemo5 private constructor() {companion object {val instance = SingletonHolder.holder}private object SingletonHolder {val holder= SingletonDemo5()}
}// Double check
class SingletonDemo6 private constructor(private val property: Int) {//这里参数可以根据实际需求发生改变companion object {@Volatile private var instance: SingletonDemo6? = nullfun getInstance(property: Int) =instance ?: synchronized(this) {instance ?: SingletonDemo6(property).also { instance = it }}}
}
java实现的双重校验反编译成smali
.class public LA001单例模式/DoubleCheckSingleInstance;
.super Ljava/lang/Object;
.source "DoubleCheckSingleInstance.java"# static fields
.field private static volatile instance:LA001单例模式/DoubleCheckSingleInstance;# direct methods
.method static constructor <clinit>()V.registers 1.prologue.line 4const/4 v0, 0x0sput-object v0, LA001单例模式/DoubleCheckSingleInstance;->instance:LA001单例模式/DoubleCheckSingleInstance;return-void
.end method.method public constructor <init>()V.registers 1.prologue.line 3invoke-direct {p0}, Ljava/lang/Object;-><init>()Vreturn-void
.end method.method public static getInstance()LA001单例模式/DoubleCheckSingleInstance;.registers 2.prologue.line 7sget-object v0, LA001单例模式/DoubleCheckSingleInstance;->instance:LA001单例模式/DoubleCheckSingleInstance;if-nez v0, :cond_13.line 8const-class v1, LA001单例模式/DoubleCheckSingleInstance;monitor-enter v1.line 9:try_start_7sget-object v0, LA001单例模式/DoubleCheckSingleInstance;->instance:LA001单例模式/DoubleCheckSingleInstance;if-nez v0, :cond_12.line 10new-instance v0, LA001单例模式/DoubleCheckSingleInstance;invoke-direct {v0}, LA001单例模式/DoubleCheckSingleInstance;-><init>()Vsput-object v0, LA001单例模式/DoubleCheckSingleInstance;->instance:LA001单例模式/DoubleCheckSingleInstance;.line 12:cond_12monitor-exit v1:try_end_13.catchall {:try_start_7 .. :try_end_13} :catchall_16.line 14:cond_13sget-object v0, LA001单例模式/DoubleCheckSingleInstance;->instance:LA001单例模式/DoubleCheckSingleInstance;return-object v0.line 12:catchall_16move-exception v0:try_start_17monitor-exit v1:try_end_18.catchall {:try_start_17 .. :try_end_18} :catchall_16throw v0
.end method
资料
Kotlin的5种单例模式
相关文章:
kotlin实现java的单例模式
代码 package com.flannery.interviewdemo.singleinstance//https://blog.csdn.net/Jason_Lee155/article/details/128796742 Java实现 //public class SingletonDemo { // private static SingletonDemo instancenew SingletonDemo(); // private SingletonDemo() // …...
使用 KeyValueDiffers 检测Angular 对象的变化
使用 KeyValueDiffers 检测Angular 对象的变化 ngDoCheck钩子 ngDoCheck 是 Angular 生命周期钩子之一。它允许组件在 Angular 检测到变化时执行自定义的变化检测逻辑。 当任何组件或指令的输入属性发生变化、在组件内部发生了变更检测周期或者当主动触发变更检测策略&#…...
Macos 10.13.2安装eclipse
eclipse for php 安装2021-12最后版本4.22 2021-12 R | Eclipse Packages jdk17 x64 dmg安装包,要安装jdk这个才能运行 Java Downloads | Oracle...
Android逆向学习(一)vscode进行android逆向修改并重新打包
Android逆向学习(一)vscode进行android逆向修改并重新打包 写在前面 其实我不知道这个文章能不能写下去,其实我已经开了很多坑但是都没填上,现在专利也发出去了,就开始填坑了,本坑的主要内容是关于androi…...
【深入浅出设计模式--状态模式】
深入浅出设计模式--状态模式 一、背景二、问题三、解决方案四、 适用场景总结五、后记 一、背景 状态模式是一种行为设计模式,让你能在一个对象的内部状态变化时改变其行为,使其看上去就像改变了自身所属的类一样。其与有限状态机的概念紧密相关&#x…...
Debezium系列之:Debezium Server在生产环境大规模应用详细的技术方案
Debezium系列之:Debezium Server在生产环境大规模应用详细的技术方案 一、需求背景二、Debezium Server实现技术三、技术方案流程四、生成接入配置五、新增数据库接入和删除数据库接入效果六、监控zookeeper节点程序七、新增数据库接入部署debezium server程序八、删除数据库接…...
Echart笔记
Echart笔记 柱状图带背景色的柱状图将X与Y轴交换制作为进度条 柱状图 带背景色的柱状图 将X与Y轴交换制作为进度条 //将X与Y轴交换制作为进度条 option { xAxis: {type: value,min:0,max:100,show:false,//隐藏x轴},yAxis: {type: category,data:[进度条],show:false,//隐…...
docker 笔记1
目录 1.为什么有docker ? 2.Docker 的核心概念 3.容器与虚拟机比较 3.1传统的虚拟化技术 3.2容器技术 3.3Docker容器的有什么作用? 3.4应用案例 4. docker 安装下载 4.1CentOS Docker 安装 4.2 Docker的基本组成 ?(面试)…...
HTTP Get 和 Post 的区别
分析&回答 使用规范 根据HTTP规范,GET用于信息获取,而且应该是安全的和幂等的。 根据HTTP规范,POST表示可能修改变服务器上的资源的请求。 传递参数 GET请求的数据会附在URL之后(就是把数据放置在HTTP协议头中)。…...
C++超级迷宫游戏
游戏效果 用钥匙、护盾等道具帮助你的小人通过大门、墙、怪物、岩浆等困难到达终点。 游戏代码 #include<bits/stdc.h> #include<conio.h> #include<windows.h> using namespace std; void Color(int a) {if(a0) SetConsoleTextAttribute(GetStdHandle(STD…...
CUDA小白 - NPP(3) 图像处理 Color and Sampling Conversion
cuda小白 原始API链接 NPP GPU架构近些年也有不少的变化,具体的可以参考别的博主的介绍,都比较详细。还有一些cuda中的专有名词的含义,可以参考《详解CUDA的Context、Stream、Warp、SM、SP、Kernel、Block、Grid》 常见的NppStatus…...
Android硬件通信之 串口通信
一,串口介绍 1.1 串口简介 串行接口简称串口,也称串行通信接口或串行通讯接口(通常指COM接口),是采用串行通信方式的扩展接口; 串行接口(SerialInterface)是指数据一位一位地顺序…...
高防服务器面对DDOS攻击的威胁有何必要性
高防服务器面对DDOS攻击的威胁有何必要性?分布式拒绝服务(DDoS)攻击是一种常见而危险的网络攻击形式,它可以使目标网络服务器过载,导致服务不可用。本文将深入探讨DDoS攻击的威胁,以及高防服务器在抵御这种…...
VBA中如何将if写到一行
在VBA中,可以使用以下两种方式来编写一行if语句: 使用三元运算符: Dim result As String result "Yes" If True Else "No"在这个例子中,如果条件为真,则result变量的值为"Yes"&#…...
性能测试,python 内存分析工具 -memray
Memray是一个由彭博社开发的、开源内存剖析器;开源一个多月,已经收获了超8.4k的star,是名副其实的明星项目。今天我们就给大家来推荐这款python内存分析神器。 Memray可以跟踪python代码、本机扩展模块和python解释器本身中内存分配…...
Jmeter(二十八):beanshell的使用
Beanshell 是一种轻量级的 Java 脚本,纯 Java 编写的,能够动态的执行标准 java 语法及一些扩展脚本语法,类似于 javaScript,在工作中可能用的多的就是: Beanshell 取样器:跟Http取样器并列Beanshell前置处理器:一般放在Http请求下,在请求前处理一些数据Beanshell后置处…...
数学建模:层次分析法
🔆 文章首发于我的个人博客:欢迎大佬们来逛逛 层次分析法 步骤描述 将问题条理化,层次化,构建出一个有层次的结构模型。层次分为三类:目标层,准则(指标)层,方案层。比…...
POI-TL制作word
本文相当于笔记,主要根据官方文档Poi-tl Documentation和poi-tl的使用(最全详解)_JavaSupeMan的博客-CSDN博客文章进行学习(上班够用) Data AllArgsConstructor NoArgsConstructor ToString EqualsAndHashCode public …...
大数据Flink(七十一):SQL的时间属性
文章目录 SQL的时间属性 一、Flink三种时间属性简介...
51单片机项目(7)——基于51单片机的温湿度测量仿真
本次做的设计,是利用DHT11传感器,测量环境的温度以及湿度,同时具备温度报警的功能:利用两个按键,设置温度阈值的加和减,当所测温度大于温度阈值的时候,蜂鸣器就会响起,进行报警提示。…...
Ostrakon-VL 代码辅助新体验:像使用 Codex 一样生成图像处理代码
Ostrakon-VL 代码辅助新体验:像使用 Codex 一样生成图像处理代码 1. 视觉编程的新可能 想象一下这样的场景:你看到一张经过"老照片修复"处理的图片效果,想在自己的项目中实现类似风格,却不知道从何下手编写代码。传统…...
FlowState Lab 在音频信号处理中的迁移应用效果:音高与节奏分析
FlowState Lab 在音频信号处理中的迁移应用效果:音高与节奏分析 1. 音频分析的新视角 音乐和语音信号处理一直是人工智能领域的重要研究方向。传统的音频分析方法往往需要复杂的特征工程和领域专业知识,而FlowState Lab的出现为这一领域带来了全新的可…...
DeepSeek-OCR-2实战:精准提取合同条款,自动生成结构化法律文书
DeepSeek-OCR-2实战:精准提取合同条款,自动生成结构化法律文书 1. 法律文书处理的痛点与解决方案 法律从业者每天都要处理大量合同、协议、判决书等文书材料。这些文档往往存在以下典型问题: 格式混乱:扫描件倾斜、模糊、双栏排…...
Kandinsky-5.0-I2V-Lite-5s效果展示:C++高性能推理后端优化案例
Kandinsky-5.0-I2V-Lite-5s效果展示:C高性能推理后端优化案例 1. 优化成果速览 这次针对Kandinsky-5.0-I2V-Lite-5s模型的C后端优化,取得了相当不错的成绩。在RTX 4090显卡上,单次推理耗时从原来的3.5秒降低到了2.1秒,速度提升了…...
前有张雪峰,后有张雪——这难道是天意-他们的成功最大的特点就是把事情做到极致,你只要坚持,就可能会成功!-你不坚持,不热爱,不可能会成功!-为什么摩托车发动机可以弯道超车,汽车不可以?到底中国汽车的发
前有张雪峰,后有张雪——这难道是天意-他们的成功最大的特点就是把事情做到极致,你只要坚持,就可能会成功!-你不坚持,不热爱,不可能会成功!-为什么摩托车发动机可以弯道超车,汽车不可以?到底中国汽车的发动机质量如何? 前有张雪峰,后有张雪——这难道是天意-他们的成…...
丹青识画系统GitHub协作开发指南:从代码克隆到PR提交全流程
丹青识画系统GitHub协作开发指南:从代码克隆到PR提交全流程 你是不是也遇到过这种情况?团队里几个人一起改代码,最后合并的时候发现冲突一大堆,张三改了李四的代码,王五的提交又把功能搞坏了,光是解决这些…...
sourcetree 或 vsCode提交代码报错:/usr/bin/env: ‘node’: No such file or directory
解决方法:手动将 fnm 的「当前版本路径」加入系统变量中做法:打开powershell,输入 fnm env --use-on-cd在输出内容中找到 FNM_MULTISHELL_PATH 的值通常类似:C:\Users\用户名\AppData\Local\fnm_multishells\...\bin手动添加该路径…...
Leather Dress Collection 在软件测试中的应用:自动化生成测试用例与报告
Leather Dress Collection 在软件测试中的应用:自动化生成测试用例与报告 最近和几个做测试的朋友聊天,大家普遍吐槽一件事:写测试用例和整理测试报告,太费时间了。尤其是面对一个复杂的新功能,或者是一大堆历史遗留的…...
PyJWT与云原生应用集成的终极指南:如何构建安全的微服务架构
PyJWT与云原生应用集成的终极指南:如何构建安全的微服务架构 【免费下载链接】pyjwt JSON Web Token implementation in Python 项目地址: https://gitcode.com/gh_mirrors/py/pyjwt PyJWT(Python JSON Web Token)是一个功能强大且易于…...
OpenClaw飞书机器人配置:基于gemma-3-12b-it的对话自动化
OpenClaw飞书机器人配置:基于gemma-3-12b-it的对话自动化 1. 为什么选择OpenClaw飞书本地模型组合 去年我接手了一个需要频繁处理文档和数据的项目,每天要花3小时在飞书群聊和本地文件之间来回切换。尝试过各种自动化工具后,最终选择了Open…...
