单例设计模式总结
程序员文章站
2022-04-14 19:46:04
最近看到一篇关于单例模式较为详细的讲解的文章:https://coolshell.cn/articles/265.html 下面对此文章进行摘录 (Java) // version 1.0 最为朴素的单例模式实践; public class Singleton { private static Si ......
最近看到一篇关于单例模式较为详细的讲解的文章: 下面对此文章进行摘录 (java)
// version 1.0 最为朴素的单例模式实践; public class singleton { private static singleton singleton = null; private singleton() { } public static singleton getinstance() { if (singleton== null) { singleton= new singleton(); } return singleton; } }
singleton特点:
- 私有(private)的构造函数,表明这个类是不可能形成实例了。这主要是怕这个类会有多个实例。
- 即然这个类是不可能形成实例,那么,我们需要一个静态的方式让其形成实例:getinstance()。注意这个方法是在new自己,因为其可以访问私有的构造函数,所以他是可以保证实例被创建出来的。
- 在getinstance()中,先做判断是否已形成实例,如果已形成则直接返回,否则创建实例。
- 所形成的实例保存在自己类中的私有成员中。
- 我们取实例时,只需要使用singleton.getinstance()就行了。
singleton多线程版本优化:
// version 1.4 多线程强化版本,使用双重检查和 volatile 进行屏蔽多线程作用; public class singleton { private volatile static singleton singleton = null; private singleton() { } public static singleton getinstance() { if (singleton== null) { synchronized (singleton.class) { if (singleton== null) { singleton= new singleton(); } } } return singleton; } }
// version 1.5 把类的创建委托给类装载器来进行创建; public class singleton { private volatile static singleton singleton = new singleton(); private singleton() { } public static singleton getinstance() { return singleton; } }
// version 1.6 使用私有内部类来进行隐藏,使得只有再getinstance 函数被调用的时候,类才会被闯将,使得类的创建可控; public class singleton { private static class singletonholder { private static final singleton instance = new singleton(); } private singleton (){} public static final singleton getinstance() { return singletonholder.instance; } }
使用上面三个版本进行创建,都可以保证线程安全;具体相关的议论,可以参考:
保持更新;更多内容请关注cnblogs.com/xuyaowen;
上一篇: C语言程序设计100例之(6):数字反转
下一篇: echarts 部分美化配置项使用记录