单件模式

getInstance()方法是静态的,这意味着它是一个类方法。所以可以在代码的任何地方使用SIngleton.getInstance()访问它。这和访问全局变量一样简单,只是多了一个优点:单件可以延迟实例化。

这里有两个线程都要执行这段代码:工作室扮演JVM角色判断两个线程是否可以产生两个实例。

只要把getInstance()变成同步(synchronized)方法,多线程灾难几乎就可以轻易地解决了:

这样的做法可以避免产生两个实例,但是同步会降低性能。很明显,需要确保单件模式能在多线层的状况下工作。但是似乎同步getInstance()的做法将拖垮性能,该怎么办呢?

解决办法一:使用“eagerly”创建实例,而不用延迟实例化的做法。

在静态初始化器中创建单件。这段代码保证了线程安全。我们依赖JVM在加载这个类时马上创建此唯一的单件实例。JVM保证在任何线程访问uniqueInstance静态变量前,一定先创建次此实例。

解决方法二:用“双重检查加锁”,在getInstance()中减少使用同步

利用双重检查加锁,首先检查是否实例已经创建了,如果尚未创建,才进行同步,这样一来,只有第一次会同步。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值