单例模式

本文介绍了Java中实现单例模式的两种方式:饿汉式和懒汉式。单例模式确保一个类只有一个实例,避免资源浪费和内存管理问题。饿汉式在类加载时即完成实例化,线程安全但可能造成内存浪费;懒汉式延迟实例化,非线程安全,可通过同步锁提高安全性,但会影响效率。
摘要由CSDN通过智能技术生成
单例,就是一个对象在内存中加载初始化和实例化都只有一个,以往我们创建对象都是很随意就写成 XXX xx = new XXX(); 这样每次new一个,就会在堆中新创建一个该XXX对象,这个方法也是语法糖之一,通过默认的构造方法创建对象。
如果一个大对象频繁创建销毁回收,会造成资源的浪费,一定程度上加重GC的负担,不利于内存管理。
要实现单例模式,我们只需要简单三步骤:

(1)默认无参构造方法私有化,这样外界就不能再通过new关键字来创建该对象了。

在这里插入图片描述

(2)把对象的创建设置为静态static的,这样在加载时初始化这个类的时候就会自动分配内存空间。方便外部调用该类的静态类方法。

在这里插入图片描述

(3)统一通过getInstance()方法返回该对象在内存中的唯一实例。

这里是因为static修饰的引用类型在类加载的时候只会在准备阶段分配空间,然后在初始化阶段实例化一次。
在这里插入图片描述

懒汉式

顾名思义就是非常懒,懒得在JVM加载初始化的阶段就去实例化对象并且附值给唯一实例。简单来说就是声明了个引用类型在那里,就是懒得去new 。直到别人调用了getInstance()方法,被逼的没办法了,才懒洋洋去new 实例化一个自身对象。
懒汉式是非线程安全的,可能会发生多个线程同时new,导致了单例模式失效。
解决方法就是简单粗暴在getInstance()方法加同步锁synchronized。但是加了同步锁,大家都懂得,效率很低。
在这里插入图片描述

饿汉式

饿汉式就是非常积极,仿佛就快要饿死那么冲动积极。声明了引用类型随即就附值。

饿汉式是线程安全的,不管三七二十一先把类实例化再说,从此多线程再多也只能一个个拿到早已经准备好的实例化对象返回。
缺点也是很明显的:假如有的类从头到尾都没有用上,但是它也在内存中创建了实例,就造成了垃圾对象占用内存问题。
在这里插入图片描述

单例模式先总结到这里,鞠躬。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值