java 单例模式双重检索_单例模式:为什么要双重检测

本文详细探讨了Java中的单例模式,特别是双重检查加锁(Double-Check Locking)机制,如何实现线程安全的单例模式。讨论了延迟加载和缓存的思想,并提供了使用Map实现缓存的基本示例。最后分析了单例模式的优缺点,包括时间和空间效率以及线程安全问题。
摘要由CSDN通过智能技术生成

http://blog.sina.com.cn/s/blog_6b6468720100kpif.html

3.3  延迟加载的思想

单例模式的懒汉式实现方式体现了延迟加载的思想,什么是延迟加载呢?

通俗点说,就是一开始不要加载资源或者数据,一直等,等到马上就要使用这个资源或者数据了,躲不过去了才加载,所以也称Lazy Load,不是懒惰啊,是“延迟加载”,这在实际开发中是一种很常见的思想,尽可能的节约资源。

体现在什么地方呢?看如下代码:

1009030ca3acf40ff23638be7b7a4a1b.png

3.4  缓存的思想

单例模式的懒汉式实现还体现了缓存的思想,缓存也是实际开发中非常常见的功能。

简单讲就是,如果某些资源或者数据会被频繁的使用,而这些资源或数据存储在系统外部,比如数据库、硬盘文件等,那么每次操作这些数据的时候都从数据库或者硬盘上去获取,速度会很慢,会造成性能问题。

一个简单的解决方法就是:把这些数据缓存到内存里面,每次操作的时候,先到内存里面找,看有没有这些数据,如果有,那么就直接使用,如果没有那么就获取它,并设置到缓存中,下一次访问的时候就可以直接从内存中获取了。从而节省大量的时间,当然,缓存是一种典型的空间换时间的方案。

缓存在单例模式的实现中怎么体现的呢?

4c4626aa99b096e7230e9aeb63c81a2e.png

3.5  Java中缓存的基本实现

引申一下,看看在Java开发中的缓存的基本实现,在Java中最常见的一种实现缓存的方式就是使用Map,基本的步骤是:

先到缓存里面查找,看看是否存在需要使用的数据

如果没有找到,那么就创建一个满足要求的数据,然后把这个数据设置回到缓存中,以备下次使用

如果找到了相应的数据,或

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值