两种单例模式的比较分析
2010-07-01 12:26
295 查看
实现单例模式一
这种实现方式,是非线程安全的,在并发情况下,可能有多个线程进入if语句块,从而创建了多个实例,所以非线程安全。但从空间上考虑,这种实现方式,比较节约内存空间,只有在调用getInstance方法的时候才分配对象的空间。然而时间上却,每次调用都要判断instance是否为空,故而又牺牲了时间。
该实现方法体现了延迟装载的思想,即,要用的时候才创建实例。
2. 实现单例模式二
该实现方式是线程安全的,因为在类加载的时候instance对象即被初始化且仅被初始化一次,然而该方式是以牺牲空间来换取时间的,因为不管是否该类被使用,均分配了内存空间。
该实现方法体现了缓存的思想,即提前装载了类的实例。
总结:对于第一种方式的非线程安全问题可以使用synchronized关键字来处理。
public class Singleton{ private static Singleton instance = null; private Singleton(){ System.out.println("A instance created!"); } public static Singleton getInstance(){ if(instance == null){ instance = new Singleton(); } return instance; } }
这种实现方式,是非线程安全的,在并发情况下,可能有多个线程进入if语句块,从而创建了多个实例,所以非线程安全。但从空间上考虑,这种实现方式,比较节约内存空间,只有在调用getInstance方法的时候才分配对象的空间。然而时间上却,每次调用都要判断instance是否为空,故而又牺牲了时间。
该实现方法体现了延迟装载的思想,即,要用的时候才创建实例。
2. 实现单例模式二
public class Singleton{ private static instance = new Singleton(); private Singleton(){ System.out.println("A instance created!"); } public static Singleton getInstance(){ return instance; } }
该实现方式是线程安全的,因为在类加载的时候instance对象即被初始化且仅被初始化一次,然而该方式是以牺牲空间来换取时间的,因为不管是否该类被使用,均分配了内存空间。
该实现方法体现了缓存的思想,即提前装载了类的实例。
总结:对于第一种方式的非线程安全问题可以使用synchronized关键字来处理。
相关文章推荐
- JavaWeb工程下,基于代理模式的两种层次结构比较分析
- “直接基于成本法”与“模拟权益法”两种合并报表模式比较与分析:响应新准则
- 面向对象建模与数据库建模两种分析设计方法的比较
- 高并发压力下nginx动静分离、nginx代理缓存两种模式的性能比较
- 两种高性能I/O设计模式(Reactor/Proactor)的比较
- 数据仓库中两种数据模型的分析比较
- 【翻译】两种高性能I/O设计模式(Reactor/Proactor)的比较
- 【翻译】两种高性能I/O设计模式(Reactor/Proactor)的比较
- 观察者模式的两种实现和比较
- 【翻译】两种高性能I/O设计模式(Reactor/Proactor)的比较
- 物联网操作系统与易信模式的比较分析
- 两种高性能I/O设计模式(Reactor/Proactor)的比较
- 两种高性能I/O设计模式(Reactor/Proactor)的比较
- [转]两种高性能I/O设计模式(Reactor/Proactor)的比较
- epoll的ET和LT模式比较 - 源码分析
- FTP协议分析(FTP两种连接模式详解)
- HTML与URL两种录制模式分析(转)
- 第九章 两种模式的比较
- 4种序列模式挖掘算法的比较分析
- LoadRunner 技巧之THML 与 URL两种录制模式分析