您好,登录后才能下订单哦!
这篇“如何用java代码实现高性能单例模式”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何用java代码实现高性能单例模式”文章吧。
单例是指:无论你创建了多少个引用,在堆中仅仅只有一个实例。
例如,
Person p1 = ... ;
Person p1 = ...;
在单例模式下,必须保证p1==p2。因为单例要保证p1和p2两个引用指向的是同一个实例,即引用地址是相同的。
单例模式的写法也有很多种:线程不安全的懒汉式、线程安全的懒汉式、线程安全的饿汉式、登记式等等。但从实践的角度来看,用的最多的也就只有两种方式:枚举式和双重检查式。
其中,枚举式的单例模式只需要一行代码,堪称居家旅行必备神器~如下所示。
public enum Singleton{ INSTANCE; }
OK,写完了,不信来测试一下。
public enum Singleton{
INSTANCE;
public void method(){
System.out.println("业务方法...");
}
}
class Test{
public static void main(String[] args) {
Singleton ins1 = Singleton.INSTANCE;
Singleton ins2 = Singleton.INSTANCE;
System.out.println(ins1 == ins2);
ins1.method();
}
}
运行结果:
true
业务方法...
原理:枚举类型 是天然的单例。
除了以上枚举式的单例模式以外,另一种推荐的单例写法就是 双重检查式单例,源码如下:
public class SingletonD {
private volatile static SingletonD instance = null;
private SingletonD() {
}
public static SingletonD getInstance() {
if (instance == null) {
synchronized (SingletonD.class) {
if (instance == null)
instance = new SingletonD();
}
}
return instance;
}
}
对以上源码进行两点说明:
源码中有两个if判断,第一个if是为了减少if代码块的执行次数(如果instance不为null,就不需要再执行if代码块),从而提升性能;第二个if是在加锁后的判断,目的是为了保证instance只会被new一次。这种写法有两个if,因此称为双重加锁。
instance = new SingletonD()不是一个原子性操作,可能会被JVM重排序,从而造成线程安全问题。因此需要给成员变量instance加上volatile关键字,用于防止重排序的发生。
以上就是关于“如何用java代码实现高性能单例模式”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。