如何用java代码实现高性能单例模式


这篇“如何用java代码实现高性能单例模式”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何用java代码实现高性能单例模式”文章吧。单例是指:无论你创建了多少个引用,在堆中仅仅只有一个实例。
例如,在单例模式下,必须保证p1==p2。因为单例要保证p1和p2两个引用指向的是同一个实例,即引用地址是相同的。单例模式的写法也有很多种:线程不安全的懒汉式、线程安全的懒汉式、线程安全的饿汉式、登记式等等。但从实践的角度来看,用的最多的也就只有两种方式:枚举式和双重检查式。其中,枚举式的单例模式只需要一行代码,堪称居家旅行必备神器~如下所示。
OK,写完了,不信来测试一下。运行结果:
true业务方法…原理:枚举类型 是天然的单例。除了以上枚举式的单例模式以外,另一种推荐的单例写法就是 双重检查式单例,源码如下:对以上源码进行两点说明:源码中有两个if判断,第一个if是为了减少if代码块的执行次数(如果instanc 香港云主机e不为null,就不需要再执行if代码块),从而提升性能;第二个if是在加锁后的判断,目的是为了保证instance只会被new一次。这种写法有两个if,因此称为双重加锁。instance = new SingletonD()不是一个原子性操作,可能会被JVM重排序,从而造成线程安全问题。因此需要给成员变量instance加上volatile关键字,用于防止重排序的发生。以上就是关于“如何用java代码实现高性能单例模式”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注开发云行业资讯频道。

相关推荐: leetcode后继者怎么实现

本篇内容主要讲解“leetcode后继者怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“leetcode后继者怎么实现”吧!设计一个算法,找出二叉搜索树中指定节点的“下一个”节点(也即中序后继)。如果指定节点…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 11/12 15:50
下一篇 11/12 16:21

相关推荐