单例模式(饿汉式,懒汉式)

单例模式:在整个java程序运行过程中,某个类自始至终只允许存在一个对象

两种写法:

饿汉式: 在类的加载过程中,该类的对象就已经存在了。

懒汉式:类不调用方法,内存始终没有该类的对象,可能存在线程安全的问题。synchronized

详细见如下代码:

java 复制代码
class ErHan{
    private static ErHan erHan=new ErHan();

   private ErHan() {
    }
    public  static ErHan getErHan(){
        return erHan;
    }


}
class xianCheng extends Thread{
    public xianCheng() {
    }

    @Override
    public void run() {
        //run没有返回值,无法知晓两个对象是否相同,可以打印出来
//        LanHan l = LanHan.getLanHan();
//        System.out.println(l);
        //run没有返回值,无法知晓两个对象是否相同,可以重新定义一个有返回值的方法GET()
        GET();

    }
    public static LanHan GET(){
        LanHan lanHan = LanHan.getLanHan();
        return lanHan;
    }
}
class LanHan {
    private LanHan(){}
    private static  LanHan lanHan;

    //懒汉是不调用方法,就不执行,存在线程安全问题,可以加同步锁 synchronized 保证安全
    public  static LanHan getLanHan(){
        if(lanHan==null){
            lanHan = new LanHan();
        }
        return lanHan;
    }


}

public class Single {
    public static void main(String[] args) {
        ErHan e1 = ErHan.getErHan();
        ErHan e2 = ErHan.getErHan();
        System.out.println("饿汉抢:"+e2.equals(e1));//单例模式,每次只允许一个对象,e2==e1
        //因为构造方法私有,无法new,即使继承Thread或者实现其他接口,也无法new出对象来执行线程
        //所以重新定义一个子类线程,在去抢LanHan的getLanHan方法
        xianCheng x1 = new xianCheng();
        xianCheng x2 = new xianCheng();
        x1.start();
        x2.start();
        System.out.println("懒汉抢:"+x1.GET().equals(x2.GET()));




    }
}
相关推荐
未来之窗软件服务18 小时前
幽冥大陆(五十三)人工智能开发语言选型指南——东方仙盟筑基期
开发语言·人工智能·仙盟创梦ide·东方仙盟
后端小张18 小时前
【JAVA 进阶】深入理解Sentinel:分布式系统的流量守卫者
java·开发语言·spring boot·后端·spring·spring cloud·sentinel
cheems952718 小时前
[JavaEE] CAS 介绍
java·开发语言·java-ee
zore_c18 小时前
【数据结构】栈——超详解!!!(包含栈的实现)
c语言·开发语言·数据结构·经验分享·笔记·算法·链表
lkbhua莱克瓦2418 小时前
IO练习——登入注册
java·开发语言·io流·java练习题
running up18 小时前
Spring-AOP与代理模式
java·spring·代理模式
Reuuse18 小时前
登录突然失效:Axios 拦截器判空、localStorage 脏数据与环境变量踩坑
开发语言·前端
Seven9718 小时前
递归与分治算法
java
风月歌18 小时前
小程序项目之基于微信小程序的高校课堂教学管理系统源代码(源码+文档)
java·微信小程序·小程序·毕业设计·源码
月明长歌18 小时前
【码道初阶】【Leetcode105&106】用遍历序列还原二叉树:前序+中序、后序+中序的统一套路与“先建哪边”的坑
java·开发语言·数据结构·算法·leetcode·二叉树